我有一个问题。我从这里编辑了我的房间实体:
@Entity(tableName = "users")
public class User {
public User(String username, String email, String password){
this.username = username;
this.email = email;
this.password = password;
}
public User() {}
@PrimaryKey
@ColumnInfo(name = "Username")
private String username;
@ColumnInfo(name = "Email")
private String email;
@ColumnInfo(name = "Password")
private String password;
//getters setters
到此表格:
@Entity(tableName = "users")
public class User {
public User(String username, String email, String password){
this.username = username;
this.email = email;
this.password = password;
}
public User() {}
//changes here, move userId to int instead of username
@NonNull
@PrimaryKey(autoGenerate = true)
private int id;
@NonNull
@ColumnInfo(name = "Username")
private String username;
@ColumnInfo(name = "Email")
private String email;
@ColumnInfo(name = "Password")
private String password;
//getters setters.
这就是我RoomDatabase
课的样子:
@Database(entities = {User.class}, version = 1)
public abstract class ApplicationDatabase extends RoomDatabase {
public abstract UserDao userDao();
}
我的问题是,如果我的安卓设备中的数据库发生变化,当我编辑实体时?如果我的数据库中有数据怎么办?如果我需要先将数据库放在设备上?我的用户构造函数呢,它现在可以工作了?
感谢您的任何建议
编辑实体时,需要更改数据库的版本,在这种情况下,将注释更改为 @Database(实体 = {User.class},版本 = 2)
由您决定是要删除数据库的旧数据还是要将旧版本迁移到较新版本(如果您有用户群并且不希望他们丢失数据库中保存的数据,我会推荐它,否则我建议您删除旧数据库中的信息,因为这是更简单的解决方案)。
如果您想进一步阅读有关迁移房间数据库的信息,我添加了一个链接:
https://developer.android.com/training/data-storage/room/migrating-db-versions
如您所提到的,您在删除和重新创建数据库时没有任何问题。然后在这种情况下,只需将fallbackToDestructiveMigration()
添加到您的Room
数据库构建器中,例如:
Room.databaseBuilder(getApplicationContext(), MyDb.class, "database-name")
.fallbackToDestructiveMigration() //recreate DB in case of conflict due to cache/backup
.build();
这将在您提升数据库版本时重新创建所有表,从而丢失所有以前的数据。
如果要在数据库中保留旧数据的同时更新表,则需要使用迁移,例如:
static final Migration MIGRATION_1_2 = new Migration(1, 2) {
@Override
public void migrate(SupportSQLiteDatabase database) {
database.execSQL("CREATE TABLE `Fruit` (`id` INTEGER, "
+ "`name` TEXT, PRIMARY KEY(`id`))");
}
};
Room.databaseBuilder(getApplicationContext(), MyDb.class, "database-name")
.addMigrations(MIGRATION_1_2).build();