一.概述
在Android开发中,有时我们需要将数据存储到SQLite数据库中,你可以选择直接使用SQL语句、Content Provider 或 ORM(对象关系数据映射 Object Relational Mapping)。
今天介绍几个比较流行的ORM框架。
二.介绍
1. OrmLite
OrmLite 不是 Android 平台专用的ORM框架,它是Java ORM。支持JDBC连接,Spring以及Android平台。语法中广泛使用了注解(Annotation)
官方网站:http://ormlite.com/sqlite_java_android_orm.shtml
2.SugarORM
SugarORM 是 Android 平台专用ORM。提供简单易学的APIs。可以很容易的处理1对1和1对多的关系型数据,并通过3个函数save(), delete() 和 find() (或者 findById()) 来简化CRUD基本操作。
要启用SugarORM,需要在你的应用程序 AndroidManifest.xml 配置中添加如下meta-data标签:
然后就可以从SugarORM扩展需要保存的数据类:
要添加一个User,代码如下:
官方网站:http://satyan.github.io/sugar/getting-started.html
3.GreenDAO
当性能很重要时(数据访问频繁),GreenDao是一个很快的解决方案,它能够支持数千条记录的CRUD每秒,和OrmLite相比,GreenDAO要快几乎4.5倍
GreenDAO小于100KB,所以对于应用程序APK的大小影响很小。
官方网站:http://greendao-orm.com/
4. Active Android
Active Record(活动目录)是Yii、Rails等框架中对ORM实现的典型命名方式。Active Android 帮助你以面向对象的方式来操作SQLite。
在你的项目中包含Active Android,你需要在项目的 /libs 目录下添加一个jar文件。可以从Github中获取源代码并使用Maven进行编辑。然后你应该添加这些meta-data到你应用程序的 AndroidManifest.xml 配置中:
然后在你的Activity中调用 ActiveAndroid.initialize() 方法:
现在,你可以使用Java注解来创建模型类:
官方网站:http://www.activeandroid.com/
5. Realm
Realm 是一个将可以使用的Android ORM,基于C++编写,直接运行在你的设备硬件上(不需要被解释),因此运行很快。它同时是开源跨平台的,iOS的代码可以在GitHub找到,你还可以找到Objective-C以及Swift编写的Realm使用实例。
官方网站:http://realm.io/