Android Room+LiveData+ViewModel使用小结

本文总结了如何在Android应用中结合使用Room数据库、LiveData和ViewModel实现数据持久化存储。首先介绍了Room的组件,包括Database、Entity和Dao接口,并详细讲述了它们的创建过程。接着,文章阐述了在MVVM架构下,如何在Repository和ViewModel中利用LiveData进行数据操作,确保UI的实时更新。最后,展示了在Activity中观察并响应LiveData数据变化的实现方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、简介

本文主要说明了如何组合使用Room、LiveData、ViewModel来进行数据的持久化存储

二、具体步骤

1. Room数据库的使用

Room主要包含三个组件:

  • Database:其中包含数据库持有者,并作为应用已保留的持久关系型数据的底层连接的主要接入点
  • Entity:用于表示数据库中的表
  • Dao:包含用于访问数据库的方法

其中三个组件的关系如下图所示(摘自Android开发者官网)

img

添加依赖

在应用或模块的 build.gradle 文件中添加所需工件的依赖项:

 dependencies {
   
     // Room数据库依赖
	def room_version = "2.2.6"

 	implementation "androidx.room:room-runtime:$room_version"
 	kapt "androidx.room:room-compiler:$room_version"
    
    // 协程依赖
    implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-core:1.4.0'
    implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-android:1.4.0'
    
    //LiveData和ViewModel依赖 
    implementation 'androidx.lifecycle:lifecycle-livedata-ktx:2.2.0'
    implementation 'androidx.lifecycle:lifecycle-viewmodel-ktx:2.2.0'
 }
创建实体类
@Entity
data class Record(
	@PrimaryKey(autoGenerate = true)
    val id: Long = 0,
    val title: String,
	val content: String)

使用id作为主键,令其默认值为0,这样在插入数据库时会自动为其赋值

创建Dao接口
@Dao
interface RecordDao {
   

    @Query("select * from record where title = :title")
    fun getAllRecordsByTitle(title: String)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值