这是我第一次尝试使用Room数据库,我想用20个User对象预填充数据库。但是,我正在使用的代码每次运行都会将20个用户添加到现有列表中。如何阻止它这样做?
@Database(entities = {User.class}, version = 1)
public abstract class AppDatabase extends RoomDatabase {
private static AppDatabase INSTANCE;
public abstract DataExchange dataExchange();
public static AppDatabase getAppDatabase(final Context context){
if (INSTANCE == null){
INSTANCE = Room.databaseBuilder(context,
AppDatabase.class,
"User_Database")
.addCallback(new Callback() {
@Override
public void onCreate(@NonNull final SupportSQLiteDatabase db) {
super.onCreate(db);
Executors.newSingleThreadScheduledExecutor().execute(new Runnable() {
@Override
public void run() {
getAppDatabase(context).dataExchange().insert(User.populate());
}
});
}
})
.build();
}
return INSTANCE;
}
public static void destroyInstance(){
INSTANCE = null;
}
这是User类:
@Entity(tableName = "user_table")
public class User{
public User(String name){
setName(name);
}
@PrimaryKey(autoGenerate = true)
private int uid;
@ColumnInfo(name = "Username")
private String name;
public String getName() {
return name;
}
public void setUid(int uid) {
this.uid = uid;
}
public void setName(String name) {
this.name = name;
}
public static User[] populate(){
User[] ar = new User[20];
for(int i=0; i<20;i++){
ar[i] = new User("USER "+(i+1));
}
return ar;
}
}
此外,我从中获取代码的地方在run()内有一个getInstance(context)而不是getAppDatabase(context)。我更改了它,因为在我不知道的5个库中找到了getInstance。
这是DataExchange:
@Dao
public interface DataExchange {
@Query("SELECT * FROM user_table")
List<User> getAll();
@Query("SELECT * FROM user_table where username LIKE :name ")
User findByName(String name);
@Query("SELECT COUNT(*) from user_table")
int countUsers();
@Update
void update(User user);
@Insert
void insertAll(User... users);
@Delete
void delete(User user);
}
答案 0 :(得分:0)
第1步:
向您的实体添加主键,建议在您的方案中使用int。例如:ID为1的用户在您的数据库中是唯一的。
@Entity
public class User {
@PrimaryKey
public int id;
}
https://developer.android.com/training/data-storage/room/defining-data
第2步:
为id变量分配一个值。我建议通过User类的构造函数来分配它(主要是为了防止它为0,或者防止您以后在setter中忘记分配它)
第3步:
在@Insert(在DAO类中)中定义冲突策略。当数据库尝试添加id = 1的anohter用户时,您希望数据库做什么?您要删除旧用户吗?只是忽略它?
@Insert(onConflict = OnConflictStrategy.REPLACE)
public void insertUsers(User... users);
https://developer.android.com/reference/android/arch/persistence/room/Insert
此外,我100%确信您正在猜测代码。只需查找官方文档即可。
答案 1 :(得分:0)
我建议只复制使用DB Browser for SQLite创建的数据库。这是进行预填充的最简单方法。您只需在应用中创建资产文件夹,添加文件夹数据库,然后复制数据库即可。 在要创建数据库的单例类中,只需添加 createFromAsset()方法,即可获得预先填充的数据库。照片在该链接上。
https://i.stack.imgur.com/Q5o4v.jpg
本文也对此进行了很好的描述。 https://medium.com/androiddevelopers/packing-the-room-pre-populate-your-database-with-this-one-method-333ae190e680