1

realmjs在我有一个 schema 的 react-native 应用程序中使用 DB settings。我想将该架构的属性类型从 更改intstring。所以我知道我需要执行迁移,我决定执行linear迁移。对于迁移,我遵循了 Realm 文档中的示例,并最终执行了如下操作:

const schemaList = [schemaV1,schemaV2];
let nextSchemaIndex = Realm.schemaVersion(Realm.defaultPath);
while (nextSchemaIndex < schemaList.length) {
    const migratedRealm = new Realm(schemaList[nextSchemaIndex++]);
    migratedRealm.close();
}

export default new Realm(schemaList[schemaList.length - 1]);

schemaV1是旧版本的数据库,schemaV2是更改属性类型后的最新版本的数据库。schemaV2还具有如下迁移功能:

    if (oldRealm.schemaVersion < 1) {
        const oldObjects = oldRealm.objects(TBL_MOBILE_SETTING);
        const newObjects = newRealm.objects(TBL_MOBILE_SETTING);
        for (let i = 0; i < oldObjects.length; i++) {
            newObjects[i].module    = oldObjects[i].module;
            newObjects[i].setting   = oldObjects[i].setting;
        }
    }

但最后,当我尝试运行该应用程序时,它会崩溃并显示一条错误消息

需要数据库迁移

这是否意味着schemaV2永远不会运行迁移功能?如果是这样,如何确保所有迁移功能都正常运行?还是我错过了其他东西?

编辑

我发现 RealmJS 中不允许更改列类型,我添加了一个新列并尝试执行迁移,但仍然出现相同的错误。

4

1 回答 1

0

问题是我猜的。没有调用迁移函数。我必须创建一个export const函数并在index文件中调用迁移函数,因为它是在应用程序启动时调用的文件。

于 2019-01-22T10:31:27.730 回答