AndroidStudio没有显示‘数据库检查器’本身”
创始人
2024-10-11 13:01:05
0

你需要在代码中添加以下代码,然后重新启动Android Studio,就可以在运行时检查数据库了。

    androidx.appcompat.app.AppCompatActivity
    import android.os.Bundle    
    import androidx.room.Room
    import androidx.room.RoomDatabase

    ...

    //创建数据库实例
    val db = Room.databaseBuilder(
        applicationContext,
        MyDatabase::class.java, "database-name"
    ).build()

    //在这里添加代码以启用数据库检查器
    if (BuildConfig.DEBUG) {
        val db = Room.databaseBuilder(
                applicationContext,
                MyDatabase::class.java, "database-name"
            )
            .allowMainThreadQueries()
            .build()
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
            val builder = AndroidSqliteDriver.Companion.inMemoryDatabaseBuilder(
                InstrumentationRegistry.getInstrumentation().context,
                MyDatabase.Schema
            )
            val driver = builder.build()
            val database = MyDatabase(driver)
        } else {
            val driver = AndroidSqliteDriver(dbHelper)
            val database = MyDatabase(driver)
        }
        Stetho.initializeWithDefaults(this)
        val initializerBuilder = Stetho.newInitializerBuilder(this)

        initializerBuilder.enableWebKitInspector(
                Stetho.defaultInspectorModulesProvider(this)
        )


        initializerBuilder.enableDumpapp(
                Stetho.defaultDumperPluginsProvider(this)
        )

        initializerBuilder.enableWebKitInspector(
                Stetho.defaultInspectorModulesProvider(this)
        )

        initializerBuilder.build()
    }

    //定义数据库实体
    @Entity
    data class User(
        @PrimaryKey val uid: Int,
        @ColumnInfo(name = "first_name") val firstName: String?,
        @ColumnInfo(name = "last_name") val lastName: String?
    )

    //定义数据库访问对象
    @Dao
    interface UserDao {
        @Query("SELECT * FROM user")
        fun getAll(): List
    
        @Query("SELECT * FROM user WHERE uid IN (:userIds)")
        fun loadAllByIds(userIds: IntArray): List
    
        @Query("SELECT * FROM user WHERE first_name LIKE :first AND " +
               "last_name LIKE :last LIMIT 1")
        fun findByName(first: String, last: String): User
    
        @Insert
        fun insertAll(vararg users: User)
}

    //定义数据库
    @Database(entities = [User::class], version = 1)
    abstract class MyDatabase : RoomDatabase() {
        abstract fun userDao(): UserDao
    
        companion object {
            @Volatile
            private var INSTANCE: MyDatabase? = null
    
            fun getDatabase(context: Context): MyDatabase {
                val tempInstance = INSTANCE
                if (tempInstance != null)

相关内容

热门资讯

透视最新"wpk私人... 透视最新"wpk私人辅助"详细辅助透明挂教程(破解版内购技巧);支持2-10人实时对战,虚拟庄家发牌...
透视私人局"wepo... 透视私人局"wepoker透视功能下载"详细辅助玩家教你(私人局透视插件辅助);玩家必备必赢加哟《1...
透视有挂"约局吧开挂... 此外,数据分析德州(约局吧开挂神器是真的吗)辅助神器app还具备辅助透视行为开挂功能,通过对客户约局...
透视透视"wepok... 透视透视"wepoker破解版内购"详细辅助新2025版(如何设置透视攻略)1、许多玩家不知道wep...
透视ai代打"pok... 透视ai代打"pokemmo脚本辅助器"详细辅助必胜教程(私人局有透视神器),支持语音通讯、好友开房...
透视游戏"wepok... 透视游戏"wepoker私人辅助器"详细辅助插件教程(模拟器哪个教程)这是由厦门游乐互动科技有限公司...
透视挂透视"wpk显... 透视挂透视"wpk显示有作弊"详细辅助wpk教程(游戏下载软件);1.wpk显示有作弊 ai辅助创建...
透视好友"拱趴游戏破... 透视好友"拱趴游戏破解器"详细辅助透明挂教程(黑侠破解神器);拱趴游戏破解器软件透明挂更新新赛季,主...
透视免费"哈糖大菠萝... 透视免费"哈糖大菠萝有挂吗"详细辅助解密教程(透视挂底牌软件);实战中需综合运用上述技巧,并根据牌桌...
透视线上"we-po... 透视线上"we-poker靠谱吗"详细辅助技巧教程(透视脚本免费app方法);建议优先通过we-po...