Android Jetpack 之 Room ---入门使用

前言

最近在学习 Google 推出的框架Jetpack,虽然目前网上的资料已经很多了,但为了加深印象和边动手练习跟着学习,所以站在了下面的巨人的肩膀上,并根据当前最新的API 和编写实际Demo,记录下一些学习笔记,大部分是参考巨人们的,整理和休整,加入自己理解和更新吧,学习领略了Android Jetpack组件的一点魅力

目前学习笔记系列为:

日常鸣谢巨人

Google官方博文

CSDN 博主Alex@W

正题

Room 简介

Room是Google提供的一个ORM库

Room提供了三个主要的组件

  1. @Database:@Database用来注解类,并且注解的类必须是继承自RoomDatabase的抽象类。该类主要作用是创建数据库和创建Daos(data access objects,数据访问对象)
  2. @Entity:@Entity用来注解实体类,@Database通过entities属性引用被@Entity注解的类,并利用该类的所有字段作为表的列名来创建表
  3. @Dao:@Dao用来注解一个接口或者抽象方法,该类的作用是提供访问数据库的方法。在使用@Database注解的类中必须定一个不带参数的方法,这个方法返回使用@Dao注解的类

入门使用

添加依赖

    apply plugin: 'kotlin-android'
    
    apply plugin: 'kotlin-android-extensions'
    
    apply plugin: 'kotlin-kapt'
    
    def room_version = "1.1.1"
    implementation "android.arch.persistence.room:runtime:$room_version"
    // use kapt for Kotlin
    annotationProcessor "android.arch.persistence.room:compiler:$room_version"
    
    // optional - RxJava support for Room
    implementation "android.arch.persistence.room:rxjava2:$room_version"
    
    // optional - Guava support for Room, including Optional and ListenableFuture
    implementation "android.arch.persistence.room:guava:$room_version"
    
    kapt 'android.arch.persistence.room:compiler:1.1.1'

创建实体类 用 @Entity 注解

    @Entity(tableName = "users")
    class User {
        @PrimaryKey(autoGenerate = true)
        var uid: Int = 0
    
        @ColumnInfo(name = "user_name")
        var name: String = ""
    
        @ColumnInfo(name = "user_age")
        var age: Int = 0
    
        override fun toString(): String {
            return "{User, uid : $uid ,name : $name ,age :$age}"
        }
    }
  1. tableName = "users" 表名
  2. ColumnInfo(name = "user_name") 列名
  3. PrimaryKey(autoGenerate = true) 主键,自增长

创建访问数据库的接口类 使用@DAO注解

主要是声明访问数据库的方法

    @Insert
    fun insertAll(vararg users: User)

    @Delete
    fun delete(user: User)

    @Delete
    fun deleteAll(users: List<User>)

    @Query("SELECT * FROM users")
    fun getAllUsers():List<User>

    @Update
    fun updateUser(user: User)

针对 SQLite的 CURD 四大操作,分别对应四种注解

  1. @Insert
  2. @Delete
  3. @Query("SELECT * FROM users")
  4. @Update

创建 AppDataBase ,使用 @Database 注解

    @Database(entities = arrayOf(User::class), version = 2)
    abstract class AppDataBase : RoomDatabase() {
    
        // 必须包含一个具有0个参数且返回带@Dao注释的类的抽象方法
        abstract fun userDao(): UserDao
    
        companion object {
            private var appDataBase: AppDataBase? = null
            fun getInstance(context: Context): AppDataBase? {
                if (appDataBase == null) {
                    synchronized(AppDataBase::class.java) {
                        appDataBase = Room.databaseBuilder(context.applicationContext,     AppDataBase::class.java, "user_database").build()
                    }
                }
                return appDataBase!!
            }
        }
    }
  1. version = 2 数据库版本,更新数据库模型时,需要更新
  2. entities = ,对应使用 @Entity 标记的实体类
  3. abstract fun userDao(): UserDao 必须包含一个具有0个参数且返回带@Dao注释的类的抽象方法,也就是返回 @Dao 标记的访问数据库的接口类
  4. 使用单例,提供外部获得AppDataBase 实例的创建

创建数据库,并执行 CURD操作

    // init dao
    userDao = AppDataBase.getInstance(this)!!.userDao()
    
    // 增加用户
    val user = User()
    user.name = "用户A"
    user.age = 20
    rDao!!.insertAl(user)
    
    //查找全部用户
    val users =userDao!!.getAllUsrs()
    
    //删除指定id 用户
     val user = User()
     user.uid = 1
     userDao!!.delee(user)
     
    //更新某指定id 用户
    val user = User()
    user.uid = 1
    user.name = "用户A被改名了"
    userDao!!.updateUser(user)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,607评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,047评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,496评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,405评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,400评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,479评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,883评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,535评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,743评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,544评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,612评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,309评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,881评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,891评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,136评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,783评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,316评论 2 342