要在Android中使用Room库预填充数据库,可以按照以下步骤进行操作:
@Database(entities = {User.class}, version = 1, exportSchema = false)
public abstract class AppDatabase extends RoomDatabase {
public abstract UserDao userDao();
}
@Entity(tableName = "users")
public class User {
@PrimaryKey
@NonNull
private String id;
private String name;
public User(String id, String name) {
this.id = id;
this.name = name;
}
// getters and setters
}
@Dao
public interface UserDao {
@Insert
void insert(User user);
@Query("SELECT * FROM users")
List getAllUsers();
}
public class MyApp extends Application {
private static AppDatabase sAppDatabase;
@Override
public void onCreate() {
super.onCreate();
sAppDatabase = Room.databaseBuilder(getApplicationContext(),
AppDatabase.class, "my-database")
.addCallback(new RoomDatabase.Callback() {
@Override
public void onCreate(@NonNull SupportSQLiteDatabase db) {
super.onCreate(db);
// 在这里填充数据库
Executors.newSingleThreadExecutor().execute(new Runnable() {
@Override
public void run() {
sAppDatabase.userDao().insert(new User("1", "John"));
sAppDatabase.userDao().insert(new User("2", "Jane"));
// 添加其他预填充的数据
}
});
}
})
.build();
}
public static AppDatabase getAppDatabase() {
return sAppDatabase;
}
}
List userList = MyApp.getAppDatabase().userDao().getAllUsers();
这样,当应用程序首次启动时,Room库将自动填充数据库。
注意:此方法只会在数据库被创建时执行,即第一次启动应用程序时。如果需要在每次应用程序启动时都填充数据库,可以在Room的Callback的onOpen方法中执行填充操作。
希望对你有所帮助!