带有预填充数据库的房间

Room with prepopulated database

在我的应用程序中,我使用带有预填充数据库 myDatabase.db 的 Room,然后使用以下代码访问该数据库:

private val database = Room
        .databaseBuilder(context.applicationContext, AppDatabase::class.java, dbName)
        .createFromAsset("myDatabase.db")
        .build()

文件myDatabase.db保存在/assets/文件夹中。然后我不得不在这样的数据库中的 tables 上添加一些新行。之后,我得到了一个更新的 myDatabase.db 文件,我将其复制到 /assets/ 文件夹以替换旧文件。问题来了:安装应用程序后,它仍然使用旧数据。我做了一些搜索,但只找到了与迁移相关的结果。但是,就我而言,table 的架构没有变化,只是添加了一些新行。此外,我不明白为什么该应用程序不选择新的 myDatabase.db 文件而仍然使用旧文件。

让应用程序使用新文件 myDatabase.db 的唯一解决方案是卸载应用程序,然后重新安装,但这是我想避免的事情。那么,如何更改 assets 文件夹中的文件 myDatabase.db 并让应用程序通过 Room 选择新文件中的数据?

Furthermore, I don't understand why the app doesn't pick the new myDatabase.db file and still uses the old one.

Room 数据库是持久的,直到它被删除。 createFromAsset 只会在数据库不存在时调用,因此在正常情况下它不会替换现有数据库。

假设应用程序只读取预先填充的数据库的解决方案是:-

  1. 添加 fallbackToDestructiveMigration or fallbackToDestructiveMigrationFrom
  2. 增加数据库版本号
  3. 不要从旧版本迁移到新版本

迁移而不是失败将删除数据库,然后尝试创建它。这样做时,它将从新资产创建数据库。