Android中GreenDao数据库框架的使用

之前就用过这个数据库框架,一直没有事件写出来,今天终于有时间记录下啦。现在用的是3.2的版本,故以GreenDao的3.2的版本为主,记录下自己对这个框架的使用。

1、了解GreenDao3.2

1)orm是对象与数据的映射,简而言之就是让java实体与数据库建立绑定的联系;

2)我们所熟知的数据库又可分之为层次式数据库网络式数据库关系式数据库三种,然而我们在使用时有经常分为关系型和非关系型两种;

关系型数据库有如下几种:orcal、mysql、dbll、sybase

非关系型数据库有如下几种:hbase、mongodb、redis

2、我们今天所说的这种数据库框架就属于基于Android内部的Sqlite封装的关系型数据库,它 是一款开源的面向 Android 的轻便、快捷的 ORM 框架,将 Java 对象映射到 SQLite  数据库中,我们操作数据库的时候,不在需要编写复杂的 SQL语句, 在性能方面,GreenDao 针对 Android 进行了高度优化,  最小的内存开销 、依赖体积小 同时还是支持数据库加密。

3、官网地址:http://greenrobot.org/greendao/;源码地址:github 地址:https://github.com/greenrobot/greenDAO

4、GreenDao的特征

1)、GreenDao是ORM框架,便于java对象映射到Sqlite数据库中保存(对象映射ORM);

2)、高性能

3)、支持加密:能够安全的保存用户的信息到数据库

4)、轻量级:GreenDao  核心库小于100k ,故我们并不会担心添加 GreenDao  后 APK 大小会变的是否庞大。

5)、开源代码自动生成:根据配置信息自动生成核心管理类以及 DAO 对象

5、GreenDao在Android中的配置

5.1设置仓库与配置(在progect目录下的build.gradle)


5.2配置依赖关系(在app目录下的build.gradle)

添加插件、配置


添加GreenDao的引用


5.3点击Sync Progect Width Gradle Files 完成配置

6、入门

6.1我们写一个简单的实体,试下效果:


6.2点击 Make Project(或者RebuildProgect或CleanProgect) 编译一下工程或者刷新下gradle 。如果配置正确,会在配置的包目录下自动会生成 DaoMaster,DaoSession 和 UserDao 类

entity其他属性的使用


6.3、GreenDao在自定义的Application中的引用


6.4、数据的增删改查

7、GreenDao注解的解析:

@Entity 实体会在数据库中生成一个与其对应的表

实体类中添加的注解字段:

 schema:告知GreenDao当前实体属于哪个 schema

    schema active:标记一个实体处于活跃状态,活动实体有更新、删除和刷新方法

    nameInDb:在数据库中使用的别名,默认使用的是实体的类名,

    indexes:定义索引,可以跨越多个列

    createInDb:标记创建数据库表(默认:true)

    generateConstructors  自动创建全参构造方法(同时会生成一个无参构造方法)(默认:true)

    generateGettersSetters  自动生成 getters and setters 方法(默认:true)

@Id对应数据库表中的字段

@Index 使用@Index作为一个属性来创建一个索引,默认是使用字段名

@Unique表名该属性在数据库中只能有唯一值

@Transient 添加此标记后不会生成数据库表的列

@ToOne表示一对一关系

@ToMany定义一对多个实体对象的关系

@OrderBy 更加某一字段排序 ,例如:@OrderBy("date ASC")

@NotNull  设置数据库表当前列不能为空

 @Property设置一个非默认关系映射所对应的列名,默认是使用字段名,例如:@Property(nameInDb = "userName")

以上就是所有的内容,再遇到新的再补充

源码下载地址:https://download.csdn.net/download/smxueer/10361024










猜你喜欢

转载自blog.csdn.net/smxueer/article/details/80007999