数据库GreenDAO的理解和使用

Android第三方开源数据库: GreenADO,GreenADO对Android原生SQLite进行了封装,比较好用,对内存占用小,库文件比较小,官方说是小于100K,编译时间低,同时也支持了加密和缓存等;
GreenDAO官方地址: http://greenrobot.org/greendao/
GreenDAOgithub地址: https://github.com/greenrobot/greenDAO
GreenDAO使用方法如下:
1、去github下粘贴依赖:

buildscript {
    repositories {
        jcenter()
        mavenCentral() // add repository
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.3.3'
        classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2' // add plugin
    }
}
 
// In your app projects build.gradle file:
apply plugin: 'com.android.application'
apply plugin: 'org.greenrobot.greendao' // apply plugin
 
dependencies {
    compile 'org.greenrobot:greendao:3.2.2' // add library
} 

2、在你app下的build.gradle下配置数据库信息:

greendao {
    schemaVersion 1
    daoPackage 'com.anye.greendao.gen'
    targetGenDir 'src/main/java'
}

其中 schemaVersion是数据库版本,daoPackage 'com.anye.greendao.gen' 是设置DaoMaster 、DaoSession、Dao包名; targetGenDir 'src/main/java' 是设置DaoMaster 、DaoSession、Dao所在目录

3、接下来编写你要用的实体类,例如写个类叫"Test":

@Entity
public class Test {

    @Id
    private Long id;
    private String name;
    private String type;


    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getType() {
        return type;
    }

    public void setType(String type) {
        this.type = type;
    }
}

4、实体类写好后,构建一下你的项目,GreenDAO会自动帮你生成一些帮助类DaoMaster 、DaoSession、Dao:


所在的目录你可以通过配置库信息的时候改动

5、基本的使用:

 mHelper = new DaoMaster.DevOpenHelper(this,"test-db",null);
        mDatabase = mHelper.getWritableDatabase();
        mDaoMaster = new DaoMaster(mDatabase);
        mDaoSession = mDaoMaster.newSession();
        mTestDao = mDaoSession.getTestDao();

6、GreenDAO的相关方法:
list(): 所有实体都将被加载到内存中;
listLazy(): 实体懒加载到内存,必须close;(推荐使用)

LazyList<test> testList= mTestDao.queryBuilder().listLazy();
for (Test test : testList) {
        Log.d("TAG", "listLazy" + test );
                        }
testList.close();

listLazyUncached() :延迟加载不缓存数据, 每次访问结果集的时候都是从数据库中加载,而不使用缓存,必须close;
listIterator() : 自己遍历数据, 可以通过迭代遍历按需加载的数据结果集(lazily)。数据没有缓存;一旦所有元素被访问或者遍历完成,来自于listLazy()的cached lazy和来自listIterator()的lazy iterator会自动关闭cursor必须手动close;
orderAsc: 升序排序
orderDesc: 降序排序
eq():==
noteq():!=
gt(): >
t():<
ge:>=
le:<=
like():包含
between:俩者之间
in:在某个值内
notIn:不在某个值内
detachAll: 清除指定Dao类的缓存
daoSession.clear(): 清除所所有的缓存;
insert: 插入数据
delete: 按对象删除
deleteByKey: 按主键删除
deleteInTx: 删除多条记录
deleteAll(): 全部删除
update: 修改一条记录;
updateInTx: 修改多条记录
queryRaw: 查询一条记录;
QueryBuilder : 查询多条记录

//多线程查询: forCurrentThread(直接放进你自己new的子线程会报错)

final Query query = testDao.queryBuilder().build();
    new Thread(){
        @Override
        public void run() {
            List list = query.forCurrentThread().list();
        }
    }.start();

//---------------------------------------------------------
7.打开调试日志,查看GreenDAO的sql语句的拼装:
初始化的时候加上:

QueryBuilder.LOG_SQL = true;
QueryBuilder.LOG_VALUES = true;

8、GreenDAO注解:

@Entity:  GreenDAO支持的实体;
@NotNull 设置表中当前列的值不可为空
@Generated  GreenDao运行所产生的构造函数或者方法,被此标注的代码可以变更或者下次运行时清除
@Id      主键
@Unique    唯一约束 
@ToMany   一对多 
@OrderBy   排序 
@ToOne      一对一 
@ToMany   一对多
@Transient  不存储在数据库中 
@JoinEntity  定义表连接关系
@Unique  向数据库列添加了一个唯一的约束
@Keep  注解的代码段在GreenDao下次运行时保持不变
         1.注解实体类:默认禁止修改此类
          2.注解其他代码段,默认禁止修改注解的代码段

9、数据库升级:
方案一 : 第三方库: https://github.com/yuweiguocn/GreenDaoUpgradeHelper
重写DaoMaster 的 onUpgrade 方法,替换之前的javaben;
方案二 : 加入帮助类 MigrationHelper.java,在DaoMaster的onUpgrade内调判断newVersion和oldVersion是否一样,不一样就调用这个帮助类中的方法:
MigrationHelper.getInstance().migrate(db, CustomerDao.class);
MigrationHelper帮助类的详情地址: https://stackoverflow.com/questions/13373170/greendao-schema-update-and-data-migration/30334668#30334668
最后记得将版本号改一下:

greendao {
    schemaVersion 2
    daoPackage 'com.anye.greendao.gen'
    targetGenDir 'src/main/java'
}

10、总结:
参考 http://blog.csdn.net/io_field/article/details/52213972
http://blog.sina.com.cn/s/blog_af5cfb030102w20v.html
http://greenrobot.org/greendao/documentation/updating-to-greendao-3-and-annotations/
http://blog.csdn.net/liuchao9876543210/article/details/54378859</test>

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

推荐阅读更多精彩内容