房间数据库架构更新

我的应用程序处于发布模式,我正在使用房间数据库,我以前的数据库版本是 2,并启用了回退到破坏性迁移。


@Database(entities = {

        User.class,ApplicationSetting.class},

        version = 2,

        exportSchema = false)

abstract public class DatabaseContext extends RoomDatabase {


    private static final Object sLock = new Object();

    private static DatabaseContext INSTANCE;

    public static String DATABASE_NAME = AppConstants.DATABASE_NAME;


    public static DatabaseContext getInstance(Context context) {

        synchronized (sLock) {

            if (INSTANCE == null) {

                INSTANCE = Room.databaseBuilder(context.getApplicationContext(),

                        DatabaseContext.class, DATABASE_NAME)

                        .fallbackToDestructiveMigration()

                        .build();

            }

            return INSTANCE;

        }

    }

我在表中添加了一个新列并将版本更改为 3。现在我想提供从版本 2 到版本 3 的迁移,以便数据不会丢失。但我很困惑,因为在版本 2 中我启用了回退破坏性迁移,现在在版本 3 中我想保留用户数据并删除回退破坏。


我怎样才能实现这个目标?


烙印99
浏览 36回答 1
1回答

MMMHUHU

当使用fallbackToDestructiveMigration时,如果没有定义的迁移,它只会销毁(删除表并重新创建它们),因此您可以添加2到3个迁移。也就是说,如果提供了迁移,那么它就会被使用并绕过回退/破坏。推荐的另一种选择是使用fallbacktopressivemigrationfrom,这可用于定义要应用回退的特定缺失迁移。例如你可以使用.fallbackToDestructiveMigrationFrom(1,7)1 允许破坏性从 1 到 27 允许从 7 到 8 进行破坏性(添加只是为了表明可以提供多个启动版本)其他的 2 到 3、3 到 4 等将需要迁移。请注意,这是更具体的,因此如果提供 1 到 2 或 7 到 8 的迁移,将会导致异常。当使用fallbackToDestructiveMigration时,如果没有定义的迁移,它只会销毁(删除表并重新创建它们),因此您可以添加2到3个迁移。也就是说,如果提供了迁移,那么它就会被使用并绕过回退/破坏。推荐的另一种选择是使用fallbacktopressivemigrationfrom,这可用于定义要应用回退的特定缺失迁移。例如你可以使用.fallbackToDestructiveMigrationFrom(1,7)1 允许破坏性从 1 到 27 允许从 7 到 8 进行破坏性(添加只是为了表明可以提供多个启动版本)其他的 2 到 3、3 到 4 等将需要迁移。请注意,这是更具体的,因此如果提供 1 到 2 或 7 到 8 的迁移,将会导致异常。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Java