GreenDao的使用(一)

基本使用

导入和配置

  1. 在项目的build.gradle文件中添加以下代码:
repositories {
        google()
        jcenter()
        mavenCentral() //添加改行
    }

dependencies {
        classpath 'com.android.tools.build:gradle:3.5.3'

        classpath 'com.android.tools.build:gradle:3.5.3' //添加此行
        classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2' //添加此行
    }
  1. 在模块中的build.gradle中添加:
apply plugin: 'com.android.application'
apply plugin: 'org.greenrobot.greendao' //添加此行

dependencies {
    implementation 'org.greenrobot:greendao:3.2.2' //添加此行
}

  1. 在模块中的build.gradle配置参数:
android {
...
}
 
greendao {
    schemaVersion 2 //这个参数用于标识数据库的版本号,用于数据库的升级。
    daoPackage "com.example.xxx" //包名
    targetGenDir 'build/generated/source/greendao' //自动生成文件的路径(代码中是默认路径)
    generateTests true //设为true会在自动生成文件的时候进行测试
    targetGenDirTests 'src/androidTest/java' //测试文件的生成路径(同样是默认路径)
}
  1. 同步gradle。

创建储存数据的实体类

  1. 编写实体类代码
@Entity( //标志该实体类为greendao的适用范围
        nameInDb = "STUDENT", //指定该表的名字,默认从实体类名生成
        schema = "mySchema", //如有多个schema,可指定该表归属哪个schema
        active = true, //true表明该实体有更新删除刷新的方法,默认false
        createInDb = true, //标志该实体是否会在数据库中生成,默认true
        generateConstructors = true, //标志是否需要生成全属性的构造方法,默认true
        generateGettersSetters = true, //标志是否自动生成getter和setter,默认true
        indexes = {
        } //定义多列索引(我也没搞懂啥意思)
)
public class Student {

    @Id(autoincrement = true) 
    //标记为id(通常用long类型来作为id),autoincrement为自增长(只有在insert后才有id)
    private long id;

    @Index(name = "STUDENT_NUM",unique = true) //标志该属性为索引,name是名字,unique是唯一性
    private String studentNum;

    private String name; //不添加Property的属性默认也会生成列

    @Property(nameInDb = "AGE") //标记为属性(一般用于指定列名称)
    private int age;

    @NotNull //标志该属性不可空
    private String sex;

    @Transient //标志该属性不需要保存到表中
    private String nickName;
}
  1. 按build菜单的make project按钮并等待构建完成。完成后greendao会自动生成三个java文件:DaoMaster(保存Database对象以及管理session)、DaoSession(可以理解为DAO大管家,管理所有对象的DAO)、StudentDao(具体某个实体类的DAO层,对数据库进行操作)。并会对Student实体类进行一些代码生成(getter,setter,更新删除刷新方法等)。

初始化

在application的oncreate中对数据库进行初始化操作,获得一个全局的session。

public class MyApp extends Application {

    private DaoSession daoSession;

    @Override
    public void onCreate() {
        super.onCreate();
        initGreenDao();//初始化greendao
    }

    private void initGreenDao() {
        DaoMaster.DevOpenHelper helper = new DaoMaster.DevOpenHelper(this,"green_db");//使用DaoMaster中的DevOpenHelper来创建数据库。
        Database db = helper.getWritableDb();//创建数据库
        daoSession = new DaoMaster(db).newSession();//创建该数据库的全局会话
    }

    public DaoSession getDaoSession() {
        return daoSession;//全局会话的getter
    }
}

操作数据库

首先对数据库进行操作要先获取对应实体类的会话对象(session)

daoSession = MyApp.getInstance().getDaoSession();//从application中获取全局session
studentDao = daoSession.getStudentDao();

增:

  1. 构建要储存的对象
String name = String.valueOf(et_name.getText());
String num = String.valueOf(et_num.getText());
String sex = String.valueOf(et_sex.getText());
String age = String.valueOf(et_age.getText());
String nickName = String.valueOf(et_nickname.getText());

Student student = new Student();
student.setAge(age);
student.setName(name);
student.setNickName(nickName);
student.setSex(sex);
student.setStudentNum(num);
  1. 调用session的insert方法(将对象传入)
studentDao.insert(student);

查:

  1. 全部查找或按id查找单个对象
List<Student> students = studentDao.loadAll();
  1. 条件查找,greendao提供了queryBuilder这个api来帮助查找,避免了sql语句的复杂性和易错性,当然损失了一定的灵活性。
List<Student> students = studentDao.queryBuilder()
                .where(StudentDao.Properties.Name.eq(name)) //相当于sql的where语法
                .limit(2) //限制最终查找的结果数
                .offset(1) //跳过前若干个结果
                .list(); //查找与某个名字相同的学生

另外查询的结果不止有list()一种,还有其他三种,以下列举:

  • list():将查询结果直接加载到内存(List)中,简单操作,无需关闭。
  • listLazy():将查询结果按需加载到内存(LazyList)中,只有访问到才会加载缓存,必须关闭。
  • listLazyUncached():每次访问某个实体都将访问数据库,LazyList,必须关闭。
  • lazyIterator():使用迭代器来按需遍历对象,不缓存,必须关闭。

后三个懒加载都会在遍历完所有实体后自动关闭,但如果提前结束则需要手动调用close()来关闭。

  1. 多次查询。在使用了queryBuilder进行查询之后,如果需要再次查询同一个结果,可以再次同该queryBuilder.list()等方法再次获取(这样做更有效率)。或者使用queryBuilder.setParameters()来更改同一个属性的不同参数。
Query<User> query = userDao.queryBuilder().where(
    Properties.FirstName.eq("Joe"), Properties.YearOfBirth.eq(1970)
).build();//构建一个queryBuilder
List<User> joesOf1970 = query.list();//第一次获取结果
 
query.setParameter(0, "Maria");//将第0个属性的参数修改为Maria
query.setParameter(1, 1977);//将第1个属性的参数修改为1977
List<User> mariasOf1977 = query.list();//使用同一个queryBuilder进行查询
  1. 绑定线程查询。如果调用forCurrentThread()来获取当前线程的query。
Query<Student> query = studentDao.queryBuilder().build().forCurrentThread();

这样获取的query只能在当前线程进行设置参数和执行这个query,否则会出现异常。但不推荐这样做,在并发事务中操作同一个query对象会导致死锁。并且在调用这个方法时,会将设置为初始参数。

  1. SQL语句查询。可以使用SQL语句创建query。

删:

  1. 单个、指定的批量或全部删除。
studentDao.delete(student);//删除单个对象
studentDao.deleteAll();//删除全部
studentDao.deleteByKey(id);//删除该id的对象
studentDao.deleteByKeyInTx(ids);//删除id列表中的所有对象
studentDao.deleteInTx(students);//删除列表中的所有对象
  1. 利用deleteQuery批量删除符合某些条件的对象。
DeleteQuery<Student> query = studentDao.queryBuilder().buildDelete();
query.executeDeleteWithoutDetachingEntities();

改:

studentDao.update(student);

另外还有数据库升级,数据库加密等其他功能容后再整理。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351

推荐阅读更多精彩内容