微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

会议室数据库从数据库检索数据

如何解决会议室数据库从数据库检索数据

我在我的项目中使用google地图,我尝试检索经度和纬度,并从sqlite数据库向地图添加标记。当我尝试检索时,会收到 Null 。问题出在哪里?

在下面您可以找到我的代码

class App : Application() {
    var database: markerDatabase? = null
        private set

    override fun onCreate() {
        super.onCreate()
        instance = this

        database = Room.databaseBuilder(this,markerDatabase::class.java,"stopmarker.db")
            .createFromAsset("databases/stopmarker.db")
            .allowMainThreadQueries()
            .build()
    }

    companion object {
        var instance: App? = null
    }
}
interface markerDAO {
    @Query("SELECT * FROM bus_stop")
    fun getAll(): LiveData<List<Marker>>

   @Query("SELECT title FROM bus_stop")
   fun getTitle(): LiveData<List<String>>

    @Query("SELECT lat FROM bus_stop")
   fun getLatitude(): LiveData<List<Double>>

    @Query("SELECT lon FROM bus_stop")
    fun getLongitude(): LiveData<List<Double>>
}
abstract class markerDatabase : RoomDatabase() {
    abstract fun MarkerDao(): markerDAO?
}

在MainActivity中

val db = App.instance

val lat = db?.database?.MarkerDao()?.getLatitude()

val lon = db?.database?.MarkerDao()?.getLongitude()

       Log.i("My_Tag",lat?.value?.get(1).toString())

结果:

解决方法

LiveData延迟加载数据,如果要观察其中的任何更改,则应使用 Oserver 并相应地更新UI。为此,您将需要遵循MVVM设计模式。很简单。

但是,如果您只想接收数据,请使用协同程序

@Query("SELECT lat FROM bus_stop")
suspend fun getLatitude(): List<Double>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。