Android Room的使用详解

Android Room的使用详解

一:Room的基本介绍

 Room 是 Android 架构组件的一部分,Room 持久性库在 SQLite
 上提供了一个抽象层,以便在充分利用 SQLite 的强大功能的
 同时,能够流畅地访问数据库。具体来说,Room 具有以下优势:
  • 针对 SQL 查询的编译时验证。
  • 可最大限度减少重复和容易出错的样板代码的方便注解。
  • 简化了数据库迁移路径

二:Room 库由 3 个主要组件组成:

实体:

Entity 表示数据库中的一个表,必须用@Entity 进行注释。每个实体至少包含一个字段,必须定义一个主键。

DAO(数据库访问对象):

在 Room 中,您可以使用数据访问对象来访问和管理您的数据。DAO 是 Room 的主要组件,包括提供对您的应用程序数据库的访问的方法,它必须用@Dao注释。使用 DAO 代替查询构建器,让您分离数据库的不同组件,例如当前数据和统计信息,这使您可以轻松测试数据库。

数据库:

作为数据库持有者,是关系数据的主要访问点。它必须用@Database注释并扩展RoomDatabase。它还包含并返回 Dao(数据库访问对象)。

​​在这里插入图片描述

三:在 Android 应用程序中实现Room数据库

​​​​​​第一步:创建一个 Empty Activity 项目

    创建一个空的活动项目,并选择Kotlin作为语言。

第二步:添加所需的依赖项

    将以下依赖添加到应用级gradle 文件中。通过转到

    ProjectName -> src -> build.gradle.
dependencies {
    val room_version = "2.4.3"

    implementation("androidx.room:room-runtime:$room_version")
    annotationProcessor("androidx.room:room-compiler:$room_version")

    // To use Kotlin annotation processing tool (kapt)
    kapt("androidx.room:room-compiler:$room_version")
    // To use Kotlin Symbol Processing (KSP)
    ksp("androidx.room:room-compiler:$room_version")

    // optional - Kotlin Extensions and Coroutines support for Room
    implementation("androidx.room:room-ktx:$room_version")

    // optional - RxJava2 support for Room
    implementation("androidx.room:room-rxjava2:$room_version")

    // optional - RxJava3 support for Room
    implementation("androidx.room:room-rxjava3:$room_version")

    // optional - Guava support for Room, including Optional and ListenableFuture
    implementation("androidx.room:room-guava:$room_version")

    // optional - Test helpers
    testImplementation("androidx.room:room-testing:$room_version")

    // optional - Paging 3 Integration
    implementation("androidx.room:room-paging:2.5.0-beta02")
}


第三步:创建数据实体

    创建一个名为 User.kt的示例数据类。

    并调用以下代码,其中包含实体User作为实体,它表示行,first_ name、last_name、 age 表示表的列名。

import androidx.room.ColumnInfo
import androidx.room.Entity
import androidx.room.PrimaryKey
 
@Entity
data class User(
	@PrimaryKey(autoGenerate = true) val uid: Int,
	@ColumnInfo(name = "name") val firstName: String?,
	@ColumnInfo(name = "city") val lastName: String?
)

第四步:创建数据访问对象(DA0):

    现在创建一个名为UserDao.kt的接口。

    并调用以下代码,它提供了应用程序用来与用户交互的各种方法。

import androidx.room.Dao
import androidx.room.Delete
import androidx.room.Insert
import androidx.room.Query
 
@Dao
interface UserDao {
	@Query("SELECT * FROM user")
	fun getAll(): List<User>
 
	@Query("SELECT * FROM user WHERE uid IN (:userIds)")
	fun loadAllByIds(userIds: IntArray): List<User>
 
	@Insert
	fun insertAll(vararg users: User)
 
	@Delete
	fun delete(user: User)
}


第五步:​​​​​​​创建数据库

    现在创建定义实际应用程序数据库的数据库,它是应用程序持久数据的主要访问点。这个类必须满足:

    1、类必须是抽象的。

    2、该类应该用@Database注释。

    3、数据库类必须定义一个带有零参数的抽象方法并返回一个 DAO 实例。

    现在在AppDatabase.kt文件中调用以下代码。
import androidx.room.Database
import androidx.room.RoomDatabase
  
@Database(entities = arrayOf(User::class), version = 1)
abstract class UserDatabase : RoomDatabase() {
    abstract fun userDao(): UserDao
}

第六步:Room 数据库的使用

在MainActivity.kt文件中,我们可以通过为数据库提供自定义名称来创建数据库
import android.os.Bundle
import androidx.appcompat.app.AppCompatActivity
import androidx.room.Room
 
class MainActivity : AppCompatActivity() {
 
	// application's Database name
	private val DATABASE_NAME: String = "USER_DATABASE"
 
	override fun onCreate(savedInstanceState: Bundle?) {
		super.onCreate(savedInstanceState)
		setContentView(R.layout.activity_main)
 
		// get the instance of the application's database
		val db = Room.databaseBuilder(
			applicationContext, UserDatabase::class.java, DATABASE_NAME
		).build()
 
		// create instance of DAO to access the entities
		val userDao = db.userDao()
 
		// using the same DAO perform the Database operations
		val users: List<User> = userDao.getAll()
	}
}


作者:林江鹏
原文链接:https://blog.csdn.net/m0_52768965/article/details/128064067?spm=1001.2014.3001.5501

  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android RoomAndroid架构组件的一部分,它是一个持久性库,提供了对SQLite数据库的抽象层,使得在使用SQLite的强大功能的同时,能够更加方便地访问数据库。Room具有以下优势: 1. 针对SQL查询的编译时验证:Room在编译时会检查SQL查询的语法和表结构,可以最大限度地减少错误和重复的代码。 2. 方便的注解:Room使用注解来定义实体类、DAO接口和数据库,可以简化数据库操作的代码编写。 3. 简化数据库迁移路径:Room提供了数据库迁移的支持,可以方便地升级数据库版本,而不需要手动编写复杂的SQL语句。 Room库由三个主要组件组成: 1. 实体(Entity):实体是数据库中的表的映射类,使用注解来定义。每个实体类都应该有一个主键,并且可以定义索引、关联表等。 2. 数据访问对象(DAO):DAO是用于定义数据库操作的接口或抽象类,使用注解来标记。通过DAO可以定义插入、更新、删除等操作,并且可以使用SQL查询语句。 3. 数据库(Database):数据库是Room的核心组件,通过注解来定义。数据库类应该是抽象类,并且继承自RoomDatabase。在数据库类中可以定义实体类和DAO接口的关联关系,并且提供数据库的版本号和迁移策略。 以上是关于Android Room的基本介绍和组成部分的说明。通过使用Room开发者可以更加方便地进行数据库操作,并且减少了编写重复和容易出错的代码的工作量。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [AndroidRoom的基本使用](https://blog.csdn.net/qq_42326415/article/details/119608921)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Android Room 使用详解](https://blog.csdn.net/Snow_Ice_Yang/article/details/128929138)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Android Room使用详解](https://blog.csdn.net/fjnu_se/article/details/128173203)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值