GreenDao概述

前言

​ 听说GreenDao已经好几年了,从2.0还需要单独建Module来生成代码,到现在3.0以及可以用APT 注解来自动生成代码。代码写了两年后,现在真的是做什么事情都想能不能偷懒,作为数据库其实如果业务不是很繁重的话,无非就是CRUD这常年不变的四种操作。今天上手尝试了下GreenDao发现真是好用,之前担心的性能问题起始完全不用,GreenDao是以性能出名的。

​ 如果你之前完全没有听说过GreenDao的话,我在这里介绍一下 这是一款专门针对Android的Orm数据库工具,如果你连ORM是什么都不是很清楚,我建议你自行搜索一下吧。底层起始还是以SQLitedatabase存储,后面会介绍怎么用。以后再也不用写什么SQL语句了和一些乱七八糟的东西了(每次写这些东西就头大)。

GreenDao概述_第1张图片
GreenDao

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'
}

核心类

GreenDao概述_第2张图片
核心类

一旦你点击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;
    }
 }

你可能感兴趣的:(GreenDao概述)