前言
听说GreenDao已经好几年了,从2.0还需要单独建Module来生成代码,到现在3.0以及可以用APT 注解来自动生成代码。代码写了两年后,现在真的是做什么事情都想能不能偷懒,作为数据库其实如果业务不是很繁重的话,无非就是CRUD这常年不变的四种操作。今天上手尝试了下GreenDao发现真是好用,之前担心的性能问题起始完全不用,GreenDao是以性能出名的。
如果你之前完全没有听说过GreenDao的话,我在这里介绍一下 这是一款专门针对Android的Orm数据库工具,如果你连ORM是什么都不是很清楚,我建议你自行搜索一下吧。底层起始还是以SQLitedatabase存储,后面会介绍怎么用。以后再也不用写什么SQL语句了和一些乱七八糟的东西了(每次写这些东西就头大)。
GreenDao配置
buildscript {
repositories {
mavenCentral()
}
dependencies {
classpath 'org.greenrobot:greendao-gradle-plugin:3.2.1'
}
}
apply plugin: 'com.android.application'
apply plugin: 'org.greenrobot.greendao'
dependencies {
compile 'org.greenrobot:greendao:3.2.0'
}
剩下的工作你只需要定义一个实体类,然后make project就完工了。 不要纠结这些注解的意思,之后你就会明白。
@Entity
public class User {
@Id(autoincrement = true)
private Long id;
private String name;
private int age;
}
在这里再说一个小TIP:如果你按照上面步骤你会发现怎么没有新的代码,那么这些代码到底跑哪去了。起始当我们Make Project 会更加我们上面实体类生成 DaoMaster ,DaoSession Daos 一大堆类。我们可以在Module的build.gradle中来配置这些代码的位置
greendao {
targetGenDir 'src/main/java'
}
核心类
一旦你点击Make project GreenDao就会自动帮你生成代码,通过你就可以直接调用方法来操作数据库,而不用担心底层的编码, 所以生成的类你是一定要了解的。
-
DaoMaster
DaoMaster 会持有一个对应的SQLiteDatabase 和管理DAOs的对应class(不是object),它会有一些静态方法用来生成表和卸载表。同样 它还拥有内部类OpenHelper和DevOpenHelper 它们都是SQLiteOpenHelper的实现类,用来在数据中生成表。
-
DaoSession
管理所有针对指定的表的DAOs的Object(不是class) 与上面要对比。DaoSession 同样提供一些对数据库的增删改查的方法 eg insert, load, update, refresh and delete。最后DaoSession还会追踪一个特定会话(数据库中的会话)的标识。更多信息查看 session documentation.
-
DAOs
我们通常是拿到针对某个实体类的Dao 来做数据库的增删改插,所以如果是一般的数据库业务,Daos可能是你接触最多的,相对DaoSession Daos提供更多的操作数据库方法 eg: count, loadAll, and insertInTx.
核心库的初始化
废话说了这儿多,到底怎么初始化来使用呢? 我直接截取我之前使用过的代码,一看便知.
public class UserDBService {
private static final String dbName = "user_db";
private volatile static UserDBService newInstance;
private DaoMaster.DevOpenHelper openHelper;
private Context context;
private UserDBService(Context context) {
this.context = context;
1. 通过单例模式中的构造方法来初始化依次
openHelper = new DaoMaster.DevOpenHelper(context, dbName, null);
}
public static UserDBService getNewInstance(Context context) {
if (newInstance == null) {
synchronized (UserDBService.class) {
if (newInstance == null) {
newInstance = new UserDBService(context);
}
}
}
return newInstance;
}
5. 封装成方法来操作数据库
public void insertUser(User user) {
if (user == null) {
return;
}
UserDao dao = getWriteUserDao();
dao.insert(user);
}
private UserDao getWriteUserDao() {
2.获取Master 对象
DaoMaster daoMaster = new DaoMaster(getWriteDatabase());
3.获取DaoSession对象
DaoSession daoSession = daoMaster.newSession();
4.获取操作特定表的DAOs的对象 ,通过这个对象来对特定表做增删改查的操作
return daoSession.getUserDao();
}
private SQLiteDatabase getWriteDatabase() {
if (openHelper == null) {
openHelper = new DaoMaster.DevOpenHelper(context, dbName, null);
}
SQLiteDatabase db = openHelper.getWritableDatabase();
return db;
}
}