5 个最好的 Android ORM 框架

jopen 9年前

如果你正在开发一个Android应用程序,您可能需要在某个地方存储数据。您可以选择云服务(在这种情况下,使用SyncAdapter将是一个不错的主意),或存储您的数据在嵌入式SQLite数据库中。如果你选择第二个选项,你可能需要使用ORM。 在这篇文章中,将介绍一些你可以考虑在你的Android应用程序中使用的ORM框架。

 

OrmLite

OrmLite is the first Android ORM that comes to my mind. However OrmLite is not an Android ORM, it’s a Java ORM with SQL databases support. It can be used anywhere Java is used, such as JDBC connections, Spring, and also Android.

It makes heavy usage of annotations, such as @DatabaseTable for each class that defines a table, or @DatabaseField for each field in the class.

A simple example of using OrmLite to define a table would be something like this:

@DatabaseTable(tableName = "users")  public class User {      @DatabaseField(id = true)      private String username;      @DatabaseField      private String password;        public User() {          // ORMLite needs a no-arg constructor      }      public User(String username, String password) {          this.username = username;          this.password = password;      }        // Implementing getter and setter methods      public String getUserame() {          return this.username;      }      public void setName(String username) {          this.username = username;      }      public String getPassword() {          return this.password;      }      public void setPassword(String password) {          this.password = password;      }  }

OrmLite for Android is open source and you can find it on GitHub. For more information read its official documentation here.

SugarORM

SugarORM is an ORM built only for Android. It comes with an API which is both simple to learn and simple to remember. It creates necessary tables itself, gives you a simple methods of creating one-to-one and one-to-many relationships, and also simplifies CRUD by using only 3 functions, save(), delete() and find() (or findById()).

Configure your application to use SugarORM by adding these four meta-data tags to your apps AndroidManifest.xml:

<meta-data android:name="DATABASE" android:value="my_database.db" />  <meta-data android:name="VERSION" android:value="1" />  <meta-data android:name="QUERY_LOG" android:value="true" />  <meta-data android:name="DOMAIN_PACKAGE_NAME" android:value="com.my-domain" />

Now you may use this ORM by extending it in the classes you need to make into tables, like this:

public class User extends SugarRecord<User> {      String username;      String password;      int age;      @Ignore      String bio; //this will be ignored by SugarORM        public User() { }        public User(String username, String password,int age){          this.username = username;          this.password = password;          this.age = age;      }  }

So adding a new user would be:

User johndoe = new User(getContext(),"john.doe","secret",19);  johndoe.save(); //stores the new user into the database

Deleting all the users of age 19 would be:

List<User> nineteens = User.find(User.class,"age = ?",new int[]{19});  foreach(user in nineteens) {      user.delete();  }

For more, read SugarORM’s online documentation.

GreenDAO

When it comes to performance, ‘fast’ and GreenDAO are synonymous. As stated on its website, “most entities can be inserted, updated and loaded at rates of several thousand entities per second. If it wasn’t that good, these apps wouldn’t be using it. Compared to OrmLite, it is almost 4.5 times faster.

greendao-performance.png
greenDAO vs OrmLite

Speaking of size, it is smaller than 100kb, so doesn’t affect APK size very much.

Follow this tutorial, which uses Android Studio to show the usage of GreenDAO in an Android application. You can view the GreenDAO source code on GitHub, and read the GreenDAO official documentation.

Active Android

Much like other ORMs, ActiveAndroid helps you store and retrieve records from SQLite without writing SQL queries.

Including ActiveAndroid in your project involves adding a jar file into the /libs folder of your Android project. As stated in the Getting started guide, you can clone the source code from GitHub and compile it using Maven. After including it, you should add these meta-data tags into your app’s AndroidManifest.xml:

<meta-data android:name="AA_DB_NAME" android:value="my_database.db" />  <meta-data android:name="AA_DB_VERSION" android:value="1" />

After adding these tags, you can call ActiveAndroid.initialize() in your activity like this:

public class MyActivity extends Activity {      @Override      public void onCreate(Bundle savedInstanceState) {          super.onCreate(savedInstanceState);          ActiveAndroid.initialize(this);            //rest of the app      }  }

Now that the application is configured to use ActiveAndroid, you may create Models as Java classes by using Annotations:

@Table(name = "User")  public class User extends Model {      @Column(name = "username")      public String username;        @Column(name = "password")      public String password;        public User() {          super();      }        public User(String username,String password) {          super();          this.username = username;          this.password = password;      }  }

This is a simple example of ActiveAndroid usage. The documentation will help you understand the usage of ActiveAndroid ORM further.

Realm

Finally Realm is a ‘yet-to-come’ ORM for Android which currently only exists. It is built on C++, and runs directly on your hardware (not interpreted) which makes it really fast. The code for iOS is open source, and you can find it on GitHub.

On the website you will find some use cases of Realm in both Objective-C and Swift, and also a Registration form to get the latest news for the Android version.

Final words

These are not the only Android ORMs on the market. Other examples are Androrm and ORMDroid.

SQL knowledge is a skill that every developer should have, but writing SQL queries is boring, especially when there are so many ORMs out there. When they make your job simpler, why not use them in the first place?

How about you? What Android ORM do you use? Comment your choice below