Как получить данные из SQLite Room и назначить их переменной в Compose?Android

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Как получить данные из SQLite Room и назначить их переменной в Compose?

Сообщение Anonymous »

Как получить значение из базы данных SQLite в Android и присвоить его переменной? Я хочу использовать ранее сохраненное значение для нескольких функций в коде.
Моя база данных имеет 3 столбца, первый из которых автоматически генерируется int id (ключ), второй имеет имя type, в котором хранятся строки, используемые для фильтрации данных. Последний — контент, который также хранит строку. Этот третий на самом деле содержит полезные данные.
Дао:
@Upsert
suspend fun upsert(appData: AppData)

@Delete
suspend fun delete(appData: AppData)

@Query("SELECT * from appData WHERE type = :type ORDER BY id DESC")
fun getData(type: String): Flow

@Query("SELECT * from appData WHERE type = :type ORDER BY id DESC")
fun getDataList(type: String): List

Интерфейс репозитория:
fun getDataStream(type: String): Flow
fun getDataListStream(type: String): List

suspend fun upsertData(data: AppData)

suspend fun deleteData(data: AppData)

А это реализация автономного репозитория:
override fun getDataStream(type: String): Flow = appDataDao.getData(type)
override suspend fun deleteData(data: AppData) = appDataDao.delete(data)
override suspend fun upsertData(data: AppData) = appDataDao.upsert(data)
override fun getDataListStream(type: String): List = appDataDao.getDataList(type)

Я пытался получить данные непосредственно из моей составной функции и использовать методы синхронизации, но поскольку ни один из них не сработал, последняя версия моего кода такая:
var lastDateObjectList by remember { mutableStateOf(emptyList()) }

LaunchedEffect(streakCounterViewModel) {
coroutineScope {
streakCounterViewModel.appDataRepository.getDataStream("lastDate")
.collect { newDataList ->
lastDateObjectList = newDataList as List
}
}
}

if (lastDateObjectList.size > 1) {/*TODO*/
for (i in 1 until lastDateObjectList.size) {
LaunchedEffect(Unit) {
streakCounterViewModel.deleteData(
id = lastDateObjectList!!.id,
type = lastDateObjectList!!.type,
content = lastDateObjectList!!.content
)
}
}
}

val lastDateObject: AppData?/* = lastDateObjectList[0] ?: null*/
lastDateObject = if (lastDateObjectList.isNotEmpty())
lastDateObjectList[0]
else null

var lastDate = lastDateObject?.content ?: "00-00-0000"


Подробнее здесь: https://stackoverflow.com/questions/784 ... in-compose
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»