IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Jetpack Room使用 -> 正文阅读

[大数据]Jetpack Room使用

Room使用

回顾

数据库有多张表,一张表只能记录一种Class,Class的具体属性是这个表的列;所有对表的操作都要通过Dao来访问

注解说明:
@Enity 作用于Class上,表示创建一张表记录该Class,Class内部属性使用@ColumnInfo声明该列名字和Type
@Dao 作用于Interface,该interface主要是提供访问表进行增删改查的接口。使用对应增删改查注解标识方法
@Database 声明数据库(需为abstract),该注解属性entities需声明该数据库中的所有表,version表示该数据库的版本,数据库中声明返回Dao实例的方法

使用流程

通过Room的静态方法databaseBuilder传入context,数据库的class对象,数据库的名称(db结尾)调用build函数就创建了数据库
数据类:

@Entity(tableName = "student")
data class StudentBean(
    @PrimaryKey(autoGenerate = true) var id: Int =0,
    @ColumnInfo(name = "name", typeAffinity = ColumnInfo.TEXT) var name: String,
    @ColumnInfo(name = "age", typeAffinity = ColumnInfo.TEXT) var age: String,
    @ColumnInfo(name = "sex", typeAffinity = ColumnInfo.TEXT) var sex: String
)

Dao:

@Dao
interface StudentDao {
    @Insert
    fun insertStudent(student: StudentBean)

    @Delete
    fun deleteStudent(student: StudentBean)

    @Update
    fun updateStudent(student: StudentBean)

    @Query("select * from student")
    fun getStudentList():List<StudentBean>

    @Query("select * from student where id=:id")
    fun getStudentById(id:Int):List<StudentBean>
}
//声明
@Database(entities = [StudentBean::class],version = 2)
abstract class MyDataBase : RoomDatabase() {

     companion object{
         private const val DATABASE_NAME="my_db"
         private var instance:MyDataBase?=null
       fun getInstance(context:Context):MyDataBase{
           instance?.let {
               return it
           }
           //创建Room数据库需要三个参数:1.上下文context,2.数据库Class  3.数据库名字db结尾
           //会通过反射创建数据库ClassImpl的实例  数据库Class名字和数据库名称
           //build方法会反射创建M有MyDataBaseImpl类并调用该类的init方法
           return Room.databaseBuilder(context.applicationContext,MyDataBase::class.java,
               DATABASE_NAME)
               .addCallback(object : Callback() {

                   override fun onCreate(db: SupportSQLiteDatabase) {
                       super.onCreate(db)
                       Log.i("wwwwwwwwwwwwwww", "RoomDataBaseonCreate: ")
                   }

                   override fun onOpen(db: SupportSQLiteDatabase) {
                       super.onOpen(db)
                       Log.i("wwwwwwwwwwwwwww", "RoomDataBaseoonOpen ")
                   }

                   override fun onDestructiveMigration(db: SupportSQLiteDatabase) {
                       super.onDestructiveMigration(db)
                       Log.i("wwwwwwwwwwwwwww", "数据库被破坏 ")
                   }
               }).addMigrations(object : Migration(1,2) {
                   override fun migrate(database: SupportSQLiteDatabase) {
                       database.execSQL("ALTER TABLE student "
                               + " ADD COLUMN sex TEXT NOT NULL DEFAULT '女'")
                   }
               })

               .build()
       }
    }

    abstract fun getStudentDao():StudentDao

借助build的返回值访问Dao,进行增删改查操作

2.降序升序:在databaseBuilder函数后添加迁移策略addMigrations,构造函数的两个版本对应迁移的版本,migrate函数是匹配对应策略后进行的操作

大致原理

疑问:Dao中只是定义了访问数据库的接口,数据库也只是个抽象类返回Dao实例的接口还没有实现?

在编译期间借助KAPT插件生成@Database标记的实现类,类名只是添加了一个后缀_Impl,而@Dao也会生成对应的_Impl后缀的实现类
查看Dao的实现类发现其每一个crud都是一个事物,并且在uiThread操作会crash,如果需要多个操作按顺序进行而不是单个事务一样,需要添加@Transition标记方法,内部curd将按顺序执行
这两个生成的类可以在该目录下找到build/generated/source/kapt/debug/com/example/myapplication/room

1、databaseBuilder会创建RoomDatabase的Builder对象保存传入的参数(比如数据库的class,数据库名称,版本迁移策略,数据库打开关闭回调),初始化一些的配置参数
build中会反射创建出数据库class+_Impl的实例,然后返回。
2.获取dao之后进行curd,在crud内部首先看有没有挂起的事务,如果Thread 1提交的事务还没有结束,Thread2提交后会报crash(ThreadLocal保证)
3.接着打开数据库,也就是在进行crud的时候才会打开数据库。其中会判断是否进行迁移
4.cud的每个操作验证完23后,就会开启一个事务.beginTransaction()接着设置事务的成功或Fail。最后结束事务

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-05-09 12:46:25  更:2022-05-09 12:47:44 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 6:33:29-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码