我想将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");
}
答案 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");