Jac*_*s.S 3 android kotlin sqldelight kotlin-coroutines
SqlDelight 显然有 Kotlin 协程扩展函数,但我不知道如何实现它们,因为我找不到文档。
我有一个看起来像这样的普通查询:
val allItems
  get() = itemQueries.selectAll().mapToList()
我可以把它变成挂起功能吗?
目前 (v1.2.1) 没有对 SqlDelight 查询的挂起函数支持,但是您可以使用 Coroutines Flow 对象,这更好。为此,您需要在应用程序 gradle 中添加协程扩展库:
dependencies {
  implementation "com.squareup.sqldelight:coroutines-extensions:1.2.1"
}
然后把你的查询变成这样:
val allItems: Flow<List<Item>> = 
  itemQueries.selectAll()
    .asFlow()
    .mapToList()
此流程发出查询结果,并在每次针对该查询更改数据库时发出新结果。
然后您可以.collect{}在协程范围内获得结果。
对于单次查询,您不需要协程扩展库。相反,只需执行以下操作:
suspend fun getAllItems() = withContext(Dispatchers.IO) {
    itemQueries.selectAll().mapToList()
}
另一个答案特定于您想要对数据库中的更改做出反应的情况。