GreenDao升级、可保留历史数据

前言
在最初设计中,往往有很多因素未考虑到,在开发过程中,一些功能的改变,或者增加,使得最初的结构,无法满足当前的需求。从而需要对数据库做升级。特别是项目已经上线,自动升级,并且保留原有数据显得尤为重要。

升级步骤
1.新建类,继承DaoMaster.OpenHelper,并且重写onUpgrade(Database db,int oldVersion,int newVersion)方法,在升级方法中对数据库升级,并且对数据迁移。我这里用的大佬写的工具类MigrationHelper,地址:
https://github.com/yuweiguocn/GreenDaoUpgradeHelper
.具体方法如下:
在这里插入图片描述
2.用新建的helper类创建数据库

DataOpenHelper dataOpenHelper = new DataOpenHelper(sContext, "test", null);
DaoMaster daoMaster = new DaoMaster(dataOpenHelper.getWritableDb());
mDaoSession = daoMaster.newSession();

3.根据需要调整表结构,在对应需要更改的实体类中,增加,删除或者更改响应的字段
注:
(1).增加或者更改的字段,数据类型用基本数据类型,例如:int 使用 Integer,避免升级出错。
(2).此升级工具类中,原有数据增加字段和修改字段,默认值为null.

4.在build.gradle中,修改greendao配置的数据库版本,然后运行即可。

greendao {
    schemaVersion 2
    daoPackage 'com.zheng.greendaodemo.green'  //生成类路径
    targetGenDir 'src/main/java'
}

关于GreenDao的升级,保留原有数据,介绍完毕

特别声明:所有内容也是集各家之所长,仅记录学习,如有侵权或不对之处,还请告知,定当删除或改正。


版权声明:本文为qq_34629725原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。