前言
在最初设计中,往往有很多因素未考虑到,在开发过程中,一些功能的改变,或者增加,使得最初的结构,无法满足当前的需求。从而需要对数据库做升级。特别是项目已经上线,自动升级,并且保留原有数据显得尤为重要。
升级步骤
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的升级,保留原有数据,介绍完毕
特别声明:所有内容也是集各家之所长,仅记录学习,如有侵权或不对之处,还请告知,定当删除或改正。