java更改数据类型,更改领域字段的数据类型-Java

I would like to change the data type of a Realm field from String to int and FYI the field is also a Primary Key. I couldn't find a method in RealmMigration to solve this issue.

PS : My app is already in production and all the values that are currently in that field are integers.

EDIT 1

My Model class

public class Team extends RealmObject {

@SerializedName("id")

@PrimaryKey

private int id;

@SerializedName("name")

private String name;

@SerializedName("description")

private String description;

}

my migration after trying Christian's answer

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");

}

解决方案

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");

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值