通过主键查询实体不使用房间

发布于 2025-02-04 00:32:22 字数 1209 浏览 3 评论 0原文

我正在尝试通过ID从我的房间数据库中查询实体,而不会成功。在这里,我的数据库:

实体:

@Entity(tableName = "artist")
data class Artist(
    @PrimaryKey(autoGenerate = true) val id: Long = 0,
    val name: String,
)

呼吸:

@Singleton
class AppRepository @Inject constructor(
    private val artistDao: ArtistDao
) {

    suspend fun insert(artist: Artist) {
          artistDao.insert(artist)
    }

   fun getArtist(id: Long) = artistDao.getArtist(id)
}

dao:

@Query("SELECT * FROM artist WHERE id = :id")
fun getArtist(id: Long): Flow<Day>

viewModel:

@HiltViewModel
class ArtistViewModel @Inject constructor(
private val repository: AppRepository,
private val savedStateHandle: SavedStateHandle
) : ViewModel() {

private val artistId: Long = 
        savedStateHandle.get(ARTIST_ID_SAVED_STATE_KEY) ?: 0

fun insert(artist: Artist) = viewModelScope.launch {
repository.insert(artist)
}

val artist =
    repository.getArtist(artistId).distinctUntilChanged().asLiveData()
}

viewmodel返回始终为null。另一方面,当我使用name Artist实体的字段做同样的事情时,我会得到一些值。 我想知道在由主钥匙查询时是否还有其他事情要注意。

I am trying to query entities from my room database by id without success. Here my database:

Entity:

@Entity(tableName = "artist")
data class Artist(
    @PrimaryKey(autoGenerate = true) val id: Long = 0,
    val name: String,
)

Respository:

@Singleton
class AppRepository @Inject constructor(
    private val artistDao: ArtistDao
) {

    suspend fun insert(artist: Artist) {
          artistDao.insert(artist)
    }

   fun getArtist(id: Long) = artistDao.getArtist(id)
}

Dao:

@Query("SELECT * FROM artist WHERE id = :id")
fun getArtist(id: Long): Flow<Day>

ViewModel:

@HiltViewModel
class ArtistViewModel @Inject constructor(
private val repository: AppRepository,
private val savedStateHandle: SavedStateHandle
) : ViewModel() {

private val artistId: Long = 
        savedStateHandle.get(ARTIST_ID_SAVED_STATE_KEY) ?: 0

fun insert(artist: Artist) = viewModelScope.launch {
repository.insert(artist)
}

val artist =
    repository.getArtist(artistId).distinctUntilChanged().asLiveData()
}

Observing the artist field from viewModel returns always null. On the other hand when I do the same thing using the name field of the Artist entity I get some value.
I'm wondering if there are some other things to pay attention when querying by the primary key.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

无边思念无边月 2025-02-11 00:32:22

有两件事:

首先 - 您将其插入数据库中:

fun insert(artist: Artist) = viewModelScope.launch {
    repository.insert(artist)
    //savedStateHandle[ARTIST_ID_SAVED_STATE_KEY] = artist.id
}

但切勿更改SavedStateHandle

第二Artist不会更改,因为您可以在ArtistID为0*和Artist对更改的更改中没有反应ArtistId

        val artist = savedStateHandle.getStateFlow<String>(ARTIST_ID_SAVED_STATE_KEY)
                                     .mapLatest { id -> 
                           repository.getArtist(id)//suspend fun
                     }.distinctUntilChanged().asLiveData()

There are two things:

First - You insert it into the database:

fun insert(artist: Artist) = viewModelScope.launch {
    repository.insert(artist)
    //savedStateHandle[ARTIST_ID_SAVED_STATE_KEY] = artist.id
}

but never changing the savedStateHandle.

Second. The artist won't change because you initialize it at view model creation where artistId is 0* and artist has no reaction on the change of the artistId.

        val artist = savedStateHandle.getStateFlow<String>(ARTIST_ID_SAVED_STATE_KEY)
                                     .mapLatest { id -> 
                           repository.getArtist(id)//suspend fun
                     }.distinctUntilChanged().asLiveData()
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文