GreenDao3.0的使用方法总结

        最近一段时间通过对数据库操作的新方法的学习,发现了一种操作简单的框架,所以小弟在这里进行了一下简单总结,希望能帮到其他开发学习者,接下来让我们了解下这个框架,greenDAO是一个对象关系映射(ORM)的框架,能够提供一个接口通过操作对象的方式去操作关系型数据库,它能够让你操作数据库时更简单、更方便。

一,首先我们先了解下GreenDao优点

1,性能高,号称Android最快的关系型数据库.

2,内存占用小.

3,库文件比较小,小于100k.

4,支持数据库加密greendao支持SQLCiPher.

5,简洁易用的API.

二,总结一下GreenDao的使用方法。

1.首先我们在project的gradle文件中引入greenDAO插件,引入之后如下:

GreenDao3.0的使用方法总结_第1张图片
project的gradle文件的配置

然后在module的gradle文件中添加greenDAO的插件,并引入相关类库,修改之后的效果如下:

GreenDao3.0的使用方法总结_第2张图片
module的gradle文件配置

我们首先应该引入相关插件,然后在dependencies中引入greenDAO的类库。至于greendao中,schemaVersion表示数据库版本号,当我们的数据库需要升级时我们修改这里的版本号即可(修改这里的版本号,greendao会自动修改生成到DAOMaster中的版本号),targetGenDir表示greenDAO生成的DAOMaster和DaoSession的位置。准备好后我们就已经成功将greenDAO引入到我们的项目中了。

2.数据库初始化

数据库引入成功后,在使用时,我们需要构建一个实体类

GreenDao3.0的使用方法总结_第3张图片
数据库实体类

@Entity表示这个实体类,点击编译按钮后一会会在数据库中生成对应的表,@Id表示该字段是Id,我们注意到该字段的数据类型为包装类型Long,为什么要用包装类型呢?因为插入数据时第一个参数是ID,如果为null,字段会自动增长。@Property则表示该属性将作为表的一个字段,其中nameInDb是这个属性在数据库中对应的数据名称。到这里,写完这些之后将项目进行编译,编译成功之后系统会帮助我们生成相应的构造方法和get/set方法,并且还会在我们的包下生成DaoMaster和DaoSession(在这里提醒下所谓的编译就是点击下那个同步/编译的按钮,所有需要的类个方法就自动生成了,具体可参考小弟github上的小demo)。这里知识常用的注解,还有其他的注解需要的同学们可以自行查询。

当我们把这一步做完之后,我们就可以进行数据库的初始化了,具体操作如下:

GreenDao3.0的使用方法总结_第4张图片
数据库的初始化

首先获取一个DevOpenHelper对象,这个类有点类似于我们使用的SqliteOpenHelper,我们主要在这个类中对数据库的版本进行管理。我们对数据库基本的初始化操作就完成了,玩过hibernate的小伙伴都知道,想要操作User实体类,得先有一个UserDao,这个UserDao要怎么获取呢?在上图中我们可以看到已经获取到了。

到现在这一步,基本准备工作我们已经做完了,接下来我们就可以对数据库进行操作了,哈哈哈

GreenDao3.0的使用方法总结_第5张图片
放松一下

3.添加数据

数据库的增删改查我们都需要通过UserDao来操作,插入具体操作如下:

GreenDao3.0的使用方法总结_第6张图片
添加数据

User的第一个参数为id,这里传null的话在插入的过程中id字段会自动增长,第二个参数是username,每次插入时生成一个随机数,避免重复。

4.删除数据

删除数据和修改数据的思路一样,都是要先查找到数据:where表示查询条件,这里我是查询id小于等于9的数据,where中的参数可以有多个,就是说可以添加多个查询条件。最后的list表示查询结果是一个List集合,如果你只想查询一条数据,最后unique即可。当然,我们也可以根据id来删除数据,具体操作如下:

GreenDao3.0的使用方法总结_第7张图片
删除数据

5.修改数据

修改数据也是先查询,再进行修改:

GreenDao3.0的使用方法总结_第8张图片
修改数据

这里我添加了两个查询条件,一个是id要大于等于9,同是还要满足username like %haha%,特别注意最后的unique表示只查询一条数据出来即可。

6.查询数据

GreenDao3.0的使用方法总结_第9张图片
查询数据

其实上面删除和修改都已经涉及到查询了,查询里边有许多非常好用的函数,我这里举两个例子between表示查询id介于1到15之间的数据,limit表示查询5条数据。

7.数据库升级

数据库的升级其实就两个步骤我们来看看:

7.1修改gradle文件

首先在module的gradle文件中修改版本号:

GreenDao3.0的使用方法总结_第10张图片
更新版本号为2

7.2修改实体类

GreenDao3.0的使用方法总结_第11张图片
实体类修改

重新进行编译即可修改成新的实体类。

一般的数据库升级这样就可以了,特殊情况可能需要自己编写数据库迁移脚本,这种时候可以自定义DBHelper,定义方式如下,注意继承类:

DBHelper   extends    DaoMaster.OpenHelper {

  public    static    final    String    DBNAME ="lenve.db";

  public    DBHelper(Context context) {

  super(context, DBNAME,null);

 }

@Override

public    void    onUpgrade(SQLiteDatabase    db,int    oldVersion,int    newVersion) {

super.onUpgrade(db, oldVersion, newVersion);

}

}

可以在onUpgrade方法中进行数据库的更新修改,如果自定义了DBHelper,则数据库的初始化变为如下方式:

DBHelper devOpenHelper =newDBHelper(this);

DaoMaster daoMaster =newDaoMaster(devOpenHelper.getWritableDb());

DaoSession daoSession = daoMaster.newSession();

userDao = daoSession.getUserDao();

OK,这就是greenDAO数据库框架的一个简单学习过程。仅作为自己的一个学习记录。

具体可参考小弟上传到github上的demo:https://github.com/liuxinggithub/greendao.git

本文参考了网上资料,总结了一下使用方法,方便更多使用者的使用。

参考文档:blog.csdn.net/u012702547/article/details/52226163

你可能感兴趣的:(GreenDao3.0的使用方法总结)