• GreenDaoUpgradeHelper-greenDao的数据库升级帮助类


    官网

    https://github.com/yuweiguocn/GreenDaoUpgradeHelper/blob/master/README_CH.md

    简介

    GreenDaoUpgradeHelper是一个greenDao的数据库升级帮助类。使用它可以很容易解决数据库升级问题,只需一行代码。

    使用说明

    1.在根目录的build.gradle文件的repositories内添加如下代码:

    1. allprojects {
    2. repositories {
    3. ...
    4. maven { url "https://jitpack.io" }
    5. }
    6. }

    2.添加依赖(greendao 3.0及以上)

    1. dependencies {
    2. compile 'org.greenrobot:greendao:3.2.0'
    3. compile 'io.github.yuweiguocn:GreenDaoUpgradeHelper:v2.2.1'
    4. }

    如果你使用的greendao是3.0以前的版本,请使用下面的依赖:

    1. dependencies {
    2. compile 'de.greenrobot:greendao:2.0.0'
    3. compile 'com.github.yuweiguocn:GreenDaoUpgradeHelper:v1.0.1'
    4. }

    3.添加一个新类继承DaoMaster.OpenHelper,添加构造函数并实现onUpgrade方法,在onUpgrade方法添加如下代码即可,参数为所有的Dao类:

    1. MigrationHelper.migrate(db, new MigrationHelper.ReCreateAllTableListener() {
    2. @Override
    3. public void onCreateAllTables(Database db, boolean ifNotExists) {
    4. DaoMaster.createAllTables(db, ifNotExists);
    5. }
    6. @Override
    7. public void onDropAllTables(Database db, boolean ifExists) {
    8. DaoMaster.dropAllTables(db, ifExists);
    9. }
    10. },TestDataDao.class, TestData2Dao.class, TestData3Dao.class);

    完整代码:

    1. public class MySQLiteOpenHelper extends DaoMaster.OpenHelper {
    2. public MySQLiteOpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory) {
    3. super(context, name, factory);
    4. }
    5. @Override
    6. public void onUpgrade(Database db, int oldVersion, int newVersion) {
    7. MigrationHelper.migrate(db, new MigrationHelper.ReCreateAllTableListener() {
    8. @Override
    9. public void onCreateAllTables(Database db, boolean ifNotExists) {
    10. DaoMaster.createAllTables(db, ifNotExists);
    11. }
    12. @Override
    13. public void onDropAllTables(Database db, boolean ifExists) {
    14. DaoMaster.dropAllTables(db, ifExists);
    15. }
    16. },TestDataDao.class, TestData2Dao.class, TestData3Dao.class);
    17. }
    18. }

    4.初始化

    1. //MigrationHelper.DEBUG = true; //如果你想查看日志信息,请将DEBUG设置为true
    2. MySQLiteOpenHelper helper = new MySQLiteOpenHelper(this, "test.db",
    3. null);
    4. daoMaster = new DaoMaster(helper.getWritableDatabase());
  • 相关阅读:
    Mysql-SQL优化
    Spring SpEL表达式语言
    sqlalchemy-orm联表查询指定字段
    svg 简单的动画
    vue3初体验-基于vue3+ant design封装公共弹框
    高效管理和盘点固定资产的办法
    面试百问:项目上线后才发现bug怎么办?
    小红书电商运营实战课,从0打造全程实操(65节视频课)
    开源的代名词「GitHub 热点速览」
    【C++从入门到精通】第2篇:C++基础知识(中)
  • 原文地址:https://blog.csdn.net/ZhaiKun68/article/details/133472494