Android开发经验谈Android技术知识Android开发

Android Jetpack架构组件-Room基本使用

2020-03-31  本文已影响0人  OneXzgj

一、简介

Room有三个主要的组件:Database、Dao、Entity

Database、Dao、Entities 和 app 的关系图如下所示:

截屏2020-03-3114.55.04.png

二、如何使用

我们以简单示例来具体实现如上核心类:

1.添加依赖

添加相关room依赖包Room版本说明,读者可根据如上链接,获取最新版本及按需依赖即可

2.定义Database类

/**
 * des:Database
 * author:onexzgj
 */
@Database(entities = [Cheese::class], version = 1)   //注释1
abstract class CheeseDb : RoomDatabase() {

    abstract fun cheeseDao(): CheeseDao

    companion object {
        private var instance: CheeseDb? = null

        fun get(context: Context): CheeseDb {
            if (instance == null) {
                //注释2
                instance = Room.databaseBuilder(context, CheeseDb::class.java, "onexzgj")
                //是否允许在主线程进行查询
                    .allowMainThreadQueries()
                    .addCallback(object : RoomDatabase.Callback() {
                        override fun onCreate(db: SupportSQLiteDatabase) {
                            super.onCreate(db)
                        }         
                    })
                    .build()
            }
            return instance!!
        }
}
  defaultConfig {
        ...
        javaCompileOptions{
            annotationProcessorOptions{
                arguments=["room.schemaLocation":"$projectDir/schemas".toString()]
            }
        }
    }

这个时候,等程序运行之后,就会在根目录生成schemas目录,并且产生一个json文件,如下所示:


image.png
        //创建一个内存数据库
        //但是这种数据库的数据只存在于内存中,也就是进程被杀之后,数据随之丢失
        Room.inMemoryDatabaseBuilder(...)
                //是否允许在主线程进行查询
                    .allowMainThreadQueries() 
                //数据库创建和打开后的回调
                .addCallback()
                //设置查询的线程池,一般不需要设置
                .setQueryExecutor()
                .openHelperFactory()
                //room的日志模式
                .setJournalMode()
                //数据库升级异常之后的回滚,默认重新进行创建
                .fallbackToDestructiveMigration()
                //数据库升级异常后根据指定版本进行回滚
                .fallbackToDestructiveMigrationFrom()
                // 数据库迁移升级时使用,后文会提到
                 .addMigrations(CacheDatabase.sMigration)

3.定义Dao

@Dao
interface CheeseDao {

    @Query("select * from cheese order by name ")
    fun findAllCheese(): DataSource.Factory<Int, Cheese>    //注释1

    @Query("select * from cheese order by name ")
    fun getAllCheese(): List<Cheese>?      //注释2

    @Insert
    fun insert(cheeses: List<Cheese>)

    @Insert(onConflict = OnConflictStrategy.REPLACE)
    fun insert(cheese: Cheese)

    @Delete
    fun delete(cheese: Cheese)
}

4、定义Entity

@Entity
data class Cheese(
    @PrimaryKey(autoGenerate = true) val id: Int, val name: String
)

通过@Entity注解标注的类,则表示这个类会映射到数据库中,默认表名为类名,
通过@ PrimaryKey,标明主键,通过设置autoGenerate参数设置true,则表示主键会自增长

5、代码中使用

        val allCheese = CheeseDb.get(this).cheeseDao().getAllCheese()
        Log.d("DATATA", allCheese?.get(0)?.name + ":" + allCheese?.size)

运行结果如下所示:


运行结果.png

到这里相信对Room数据库有一个基本的了解,如果了解Orm或者GreenDao的同学,应该对上面的步骤或者创建不难理解,接下来介绍核心类的具体参数的含义及用法

三、核心类属性讲解

3.1 、@Entity注解包含的属性有:

tableName:设置表名字,默认是类的名字。
indices:设置索引,按需添加,会提高查询速度,增加更新和新增的操作时间
inheritSuperIndices:父类的索引是否会自动被当前类继承,没用到过,暂不解释
primaryKeys:设置主键,一般通过直接在主键字段上添加@PrimaryKey
foreignKeys:设置外键。
Ignore:设置不需要映射到数据库中的字段可以使用,则不会在表中出现该字段

如下所示:

@Entity(tableName = "table_cheese")
data class Cheese(
    @PrimaryKey(autoGenerate = true) val id: Int, 
    
    @ColumnInfo(name = "testName")
    val name: String,
    @Ignore
    val temp:String
)

3.2、@Query注解是

它是DAO类中使用的主要注释,允许对数据库执行读/写操作。@Query在编译的时候会验证准确性,所以如果查询出现问题在编译的时候就会报错,如字段拼写常规错误等。

Room还会验证查询的返回值,如果返回对象中的字段名称与查询响应中的相应列名称不匹配的时候,Room会通过以下两种方式之一提醒您:
如果只有一些字段名称匹配,它会发出警告。
如果没有字段名称匹配,它会发生错误。

@Query注解value参数:查询语句,根据需求,完成查询sql语句即可。

 @Query("select * from cheese  where name ==:name ")
 fun getCheese(name:String): List<Cheese>?

四、结语

到这里,Room的基本使用就差不多介绍完成了,那么在实际开发中,仅仅掌握基本使用,是远远不够的,如多表查询,一对一、一对多等关系的查询如何实现?配合Rxjava/LiveData/Paging的使用

本文示例代码已上传至Jetpack_Component

上一篇 下一篇

猜你喜欢

热点阅读