Android - Как можно предварительно заполнить данные в базе данных комнат в kotlin (обновлено)? - PullRequest
1 голос
/ 06 февраля 2020

У меня есть база данных в комнате Kotlin (Android), но я не могу предварительно заполнить ее, потому что никогда не входите в .addCallback (CALLBACK) , как я могу это сделать?

@Database(entities = [Entry::class, Category::class], version = 2, exportSchema = false)
@TypeConverters(RoomTypeConverters::class)
abstract class FinDatabase : RoomDatabase() {

    abstract val entryDao: EntryDao

    companion object {
        @Volatile
        private var INSTANCE: FinDatabase? = null
        fun getInstance(context: Context): FinDatabase {
            synchronized(this) {
                var instance = INSTANCE
                if (instance == null) {
                    instance = Room.databaseBuilder(
                        context.applicationContext,
                        FinDatabase::class.java,
                        "database"
                    )
                        .addCallback(CALLBACK)
                        .addMigrations(MIGRATION_1_2)
                        .build()
                    INSTANCE = instance
                }
                return instance
            }
        }

        private val CALLBACK = object : RoomDatabase.Callback() {
            override fun onCreate(db: SupportSQLiteDatabase) {
                super.onCreate(db)
                db.execSQL("INSERT CATEGORY (id, name) VALUES (1, \"TESTE\") ")
            }
        }
    }
}

1 Ответ

2 голосов
/ 06 февраля 2020

Я вижу, что запрос неправильный. Пожалуйста, измените ваш запрос на:

db.execSQL("INSERT INTO CATEGORY (id, name) VALUES (1, 'TESTE')")

Примечание: onCreate () CALLBACK будет вызываться только один раз (то есть) при создании базы данных (при первом запуске). Вам нужно будет удалить и перезапустить приложение, чтобы снова вызывать обратный вызов.

...