2016-06-21 10 views
3

レルムフィールドのデータ型をStringからintに変更したいのですが、このフィールドもPrimary Keyです。私はRealmMigrationでこの問題を解決する方法を見つけることができませんでした。レルムフィールドのデータ型を変更する - Java

PS:私のアプリはすでに制作中で、そのフィールドに現在あるすべての値は整数です。

EDIT 1

マイModelクラス

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

答えて

15

クリスチャンの答えをしようとした後、移行の例と同じパターン: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"); 
+0

'removePield'を使用しているときに' removePrimaryKey'が暗黙的に適用されていますか? –

+0

古い列と新しい列の名前を同じにしたいと思います...可能ですか? –

+0

@Timはい、それは1.0.1で修正されたバグでした。https://github.com/realm/realm-java/blob/master/CHANGELOG.md –

関連する問題