GreenDAO 学习笔记-小白教程(三)数据库升级及注意事项

本文介绍如何使用GreenDAO进行数据库升级,并演示了如何通过自定义MyOpenHelper类来处理数据库升级的过程,包括添加新字段和数据迁移的具体步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

数据库升级

我们可以自定义一个MyOpenHelper类,来继承DaoMaster.OpenHelper,当初始化数据库的时候,我们就可以调用这个类来新建对象:

    MyOpenHelper openHelper = new MyOpenHelper(
                    context.getApplicationContext(), DATABASE_NAME, null);
    /**
     * 定义一个MySQLiteOpenHelper类,用来处理数据库升级
     */
    static class MyOpenHelper extends DaoMaster.OpenHelper {

        public MyOpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory) {
            super(context, name, factory);
        }

        @Override
        public void onUpgrade(Database db, int oldVersion, int newVersion) {
            super.onUpgrade(db, oldVersion, newVersion);
        }
    }

在app的build.gradle文件中,将greendao 里边的schemaVersion字段增加,则做到了数据库升级的效果。再次运行程序,就会调用我们的MyOpenHelper的onUpgradle方法。

在这里,我们采用github上很有用的数据库升级数据迁移开元库GreenDaoUpgradeHelper。在数据库升级的时候,做数据迁移。具体使用方法为:

假如为Player添加一个Integer的champion字段,用来表示获得的总冠军次数。

  1. 将schemaVersion的值由1改为2.
  2. 数据迁移:覆盖MyOpenHelper的onUpgrade方法。即调用MigrationHelper的migrate方法,实现接口ReCreateAllTableListener的两个方法(这是固定的),再将PlayerDao.class作为另个一个参数传入。
  3. 修改显示champion的Adapter的方法:
    if (player.getChampion() == null) {
            holder.mTvChampion.setVisibility(View.GONE);
        } else {
            holder.mTvChampion.setVisibility(View.VISIBLE);
            holder.mTvChampion.setText(mContext.getString(R.string.player_champion, player.getChampion()));
        }
    /**
     * 定义一个MySQLiteOpenHelper类,用来处理数据库升级
     */
    static class MyOpenHelper extends DaoMaster.OpenHelper {

        public MyOpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory) {
            super(context, name, factory);
        }

        @Override
        public void onUpgrade(Database db, int oldVersion, int newVersion) {
            super.onUpgrade(db, oldVersion, newVersion);
            Log.d(TAG, "onUpgrade: old: " + oldVersion + ", new: " + newVersion);
            if (oldVersion <= 1) {
                MigrationHelper.migrate(db, new MigrationHelper.ReCreateAllTableListener() {
                    @Override
                    public void onCreateAllTables(Database db, boolean ifNotExists) {
                        DaoMaster.createAllTables(db, ifNotExists);
                    }

                    @Override
                    public void onDropAllTables(Database db, boolean ifExists) {
                        DaoMaster.dropAllTables(db, ifExists);
                    }
                }, PlayerDao.class);

            }

        }
    }

注意

新添加的字段的数据类型必须是对象类型,如果是基本数据类型,则需要改为其对应的包装类,否则,在数据库升级做数据迁移的时候,就会出现异常android.database.sqlite.SQLiteConstraintException,导致数据迁移失败,对于用户的使用体验是很差的。

数据迁移失败

Demo源代码地址

GreenDaoUpgradeHelper地址

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值