更改Realm字段的数据类型 - Java

时间:2016-06-21 13:39:32

标签: android realm

我想将Realm字段的数据类型从String更改为int,而FYI该字段也是Primary Key。我无法在RealmMigration中找到解决此问题的方法。

PS:我的应用程序已经投入生产,当前该字段中的所有值都是整数。

编辑1

我的模型类

public class Team extends RealmObject {
    @SerializedName("id")
    @PrimaryKey
    private int id;
    @SerializedName("name")
    private String name;
    @SerializedName("description")
    private String description;
}

在尝试克里斯蒂安的回答后我的迁移

if (oldVersion == 6) {
            RealmObjectSchema teamSchema = schema.get("Team");
            teamSchema.addField("temp_id", int.class)
                    .transform(new RealmObjectSchema.Function() {
                        @Override
                        public void apply(DynamicRealmObject obj) {
                            obj.setInt("temp_id", Integer.valueOf(obj.getString("id")));
                        }
                    })
                    .removeField("id")
                    .renameField("temp_id", "id")
                    .addPrimaryKey("id");
        }

1 个答案:

答案 0 :(得分:23)

没有单线方法,但您可以采用与我们的迁移示例中相同的模式:https://github.com/realm/realm-java/blob/master/examples/migrationExample/src/main/java/io/realm/examples/realmmigrationexample/model/Migration.java#L132-L132

        schema.get("MyClass")
            .addField("new_key", int.class)
            .transform(new RealmObjectSchema.Function() {
                @Override
                public void apply(DynamicRealmObject obj) {
                    obj.setInt("new_key", Integer.valueOf(obj.getString("old_key")));
                }
            })
            .removeField("old_key")
            .addPrimaryKey("new_key")
            .renameField("new_key", "old_key");