Я использую версию Gram Gram "3.0.0", у меня есть две таблицы "Word" и "Favorite", как показано ниже
Теперь я хочу добавить третью таблицу под названием «История»
для этого я сделал ниже код
@Override
public void migrate(DynamicRealm realm, long oldVersion, long newVersion) {
final RealmSchema schema = realm.getSchema();
if (oldVersion == 0) {
RealmObjectSchema wordSchema = schema.get("Word");
wordSchema.addField(DBHelper.COLUMN_NAME_PRONOUCE, String.class);
wordSchema.addField(DBHelper.COLUMN_NAME_TYPE, String.class);
oldVersion++;
} if(oldVersion == 1){
RealmObjectSchema favouriteSchema = schema.get("Favourite");
favouriteSchema.addField(DBHelper.COLUMN_NAME_ID, String.class);
favouriteSchema.addField(DBHelper.COLUMN_NAME_WORD, String.class);
favouriteSchema.addField(DBHelper.COLUMN_NAME_OBJECT_ID, String.class);
favouriteSchema.addField(DBHelper.COLUMN_NAME_PRONOUCE, String.class);
favouriteSchema.addField(DBHelper.COLUMN_NAME_TYPE, String.class);
favouriteSchema.addField(DBHelper.COLUMN_NAME_MEANING, String.class);
oldVersion++;
}
if(oldVersion == 2){
schema.create("History")
.addField(DBHelper.COLUMN_NAME_ID, String.class)
.addField(DBHelper.COLUMN_NAME_WORD, String.class)
.addField(DBHelper.COLUMN_NAME_OBJECT_ID, String.class)
.addField(DBHelper.COLUMN_NAME_PRONOUCE, String.class)
.addField(DBHelper.COLUMN_NAME_TYPE, String.class)
.addField(DBHelper.COLUMN_NAME_MEANING, String.class);
oldVersion++;
}
}
Но я получаю ошибку ниже,
io.realm.exceptions.RealmMigrationNeededException: Migration is required due to the following errors:
- Property 'History.id' has been changed from 'string' to 'int'.
- Property 'History.word' has been made required.
- Property 'History.objectId' has been made required.
- Property 'History.pronunciation' has been made required.
- Property 'History.type' has been made required.
- Property 'History.meaning' has been made required.
Я не создавал ни одной таблицы истории раньше, чем, почему она говорит, что History.id был изменен с 'string' на 'int'?
Как правильно добавить таблицу истории?