如何预填充我的会议室数据库?

时间:2018-07-18 13:10:12

标签: java android sql android-room

这是我第一次尝试使用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);

}

2 个答案:

答案 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