), 即发生冲突时替换原有数据 @Update和@Delete 可以定义int类型返回值,指更新/删除的函数 DAO中的增删改方法的定义都比较简单,这里不展开讨论,下面更多的聊一下查询方法。...语句,如果@Query() 中的sql语句存在语法错误,或者查询的表不存在,Room会在编译时报错。...2.3 查询表中部分字段的信息 在实际某个业务场景中, 我们可能仅关心一个表部分字段的值,这时我仅需要查询关心的列即可。...假设原有一个版本号为1的数据库有一张表User, 现在要迁移到Room, 我们需要定义好Entity, DAO, Database, 然后创建Database时添加一个空实现的Migraton即可。...类, 一堆代码类似的数据库访问类(DAO),访问数据库时需要做Cursor的遍历,构建并返回对应的POJO类…相比之下,Room作为在SQLite之上封装的ORM库确实有诸多优势,比较直观的体验是: 比
DAO 是 Room 的重要组件,他包含了操作数据的抽象方法; DAO可以是一个接口或者抽象类,如果是抽象类的话,它可以有一个构造函数,它将RoomDatabase作为其唯一参数。...在编译时,Room会知道是查询用户表的所有列。如果查询包含语法错误或者数据库中不存在这个表。Room会在编译时报错并给出错误信息。 将参数传递给查询 大部分时候查询都是需要过滤参数的。...json 文件加入到版本控制中,它记录了数据库的模式历史,它能让Room在测试时创建老版本的数据库。...测试数据库有两种方法 在Android 设备上 在开发主机上(不推荐) 关于测试指定数据库升级的信息 上面已经说过了。 注意:在测试时,Room允许创建Dao的模拟实例。...如果作者类引用另一个表(如Books),则应用程序的效率会进一步降低。 要使用Room同时引用多个实体,需要创建一个包含每个实体的POJO,然后编写一个查询来加入相应的表。
前言 Google终于发布了一个和SQLite相关的库了???。之前一直都是在SQLite、XUtils、greenDao、Realm这些数据库之间来回折腾。现在终于有一个更“正统”数据库了。...Room是什么? Room是一个持久性数据库。 Room持久性库提供了SQLite的抽象层,以便在充分利用SQLite的同时允许流畅的数据库访问。 为什么会选择Room?...前面我也说到了现在也有不少开源的数据库给大家使用,那为什么我们还要去学习使用这个库呢?当然不是我前面说的“正不正统”的原因了。...因为Room有下面几个优点: ① SQL查询在编译时就会验证 - 在编译时检查每个@Query和@Entity等,这就意味着没有任何运行时错误的风险可能会导致应用程序崩溃(并且它不仅检查语法问题,还会检查是否有该表...、数据库版本(每当我们改变数据库中的内容时它都会增加),所以这里使用exportSchema = false 注意:除了添加表映射的类以及和数据库版本外,还要添加exportSchema = false
也意识到了这个问题,在Jetpack组件中推出了Room,Room在SQLite上提供了一层封装,可以流畅的访问数据库。...使用@Database注解的类应满足以下条件: 是扩展RoomDatabase的抽象类。 在注释中添加与数据库关联的实体列表。 包含具有0个参数且返回使用@Dao注释的类的抽象方法。...Entity:表示数据库中的表。 DAO:包含用于访问数据库的方法。 应用使用 Room 数据库来获取与该数据库关联的数据访问对象 (DAO)。...如果应用不支持使用全文搜索,可以将数据库的某些列编入索引,加快查询速度,通过@Entity注解添加indices,列出要在索引或符合索引中包含的列名称。...DAO可以是接口,也可以是抽象类,如果是抽象类,则该DAO可以选择有一个以RoomDatabase为唯一参数的构造函数。Room 会在编译时创建每个 DAO 实现。在DAO文件上方添加@DAO注解。
Room 在官方的架构指南中占据着一个中心位置,它提供在 SQLite 上的一个抽象层,允许在充分利用 SQLite 的强大基础上进行流畅地数据库访问开发。...当然,至少在我写这篇文章的时候是这样(或许在很长一段时间之后也是这样), Room 是城里最受欢迎的那个孩子,但是我将会尽量保持对他做一个简短的介绍。...对于各个实体,数据库中的表的创建就是为了存储它们的实例。你必须通过数据库类中的实体数组来引用实体类。 DAO :这个组件代表一个数据访问对象的类或者接口。 DAO 负责定义数据库访问的方法。...查询生成器:使用 ObjectBox 查询对象和编译时错误检查都非常简单。 数据关联:对象的引用/关联是内建的内部类型,它们都属于原生本地引用。...并且,当然随着元素的数量级的增加,差距变得越来越大!对于一个新成员来说,表现得还行。可以说非常好。 ? 查询同样看上去是 ObjectBox 的一个强项。测试中采用了字符串和索引,结果不言自明。
Room有3个主要组件 Database :数据库 Entity : 代表数据库一个表结构 Dao : 包含访问数据库的方法 简单使用 添加Google Maven仓库 allprojects {...(); //要引用的外键列 String[] parentColumns(); //要关联的列 String[] childColumns(); //当父类实体(关联的外键表)从数据库中删除时执行的操作...Java对象(POJO)作为数据库逻辑中的一个完整的整体来表示,即使该对象包含几个字段。...在这些情况下,您可以使用@Embedded来表示一个对象,您希望将其分解为表中的子字段。..."$projectDir/schemas".toString()] } } } } 您应该将导出的JSON文件(表示数据库的模式历史记录)存储在您的版本控制系统中,因为它允许为测试目的创建您的数据库的旧版本
的参数存在冲突时, 可以设置 属性的值来定义冲突的解决策略, 比如代码中定义的是 , 即发生冲突时替换原有数据 和 可以定义 类型返回值,指更新/删除的函数 DAO中的增删改方法的定义都比较简单,这里不展开讨论...2.1 简单的查询 Talk is cheap, 直接show code: Room会在编译时校验sql语句,如果 中的sql语句存在语法错误,或者查询的表不存在,Room会在编译时报错。...2.3 查询表中部分字段的信息 在实际某个业务场景中, 我们可能仅关心一个表部分字段的值,这时我仅需要查询关心的列即可。...定义子集的POJO类: 在DAO中添加查询方法: 这里定义的POJO也支持使用 2.3 查询结果的返回类型 Room中查询操作除了返回POJO对象及其List以外, 还支持: : LiveData是架构组件库中提供的另一个组件...假设原有一个版本号为1的数据库有一张表User, 现在要迁移到Room, 我们需要定义好Entity, DAO, Database, 然后创建Database时添加一个空实现的Migraton即可。
我们就不难想到,Google 之所以这样设计,是因为我们于是需要创建临时的 User 对象,但我们又不希望 @Entity 在我们调用构造方法时,就将其存入数据库。...@Dao public interface UserDao { /** * 为了简便,我们只在表中存入1个用户信息 * 这个查询语句可以获得 所有 User 但我们只需要第一个即可...Google 官方对它的解释是:在一个被标注了 @Dao 标签的类中,用于查询的方法。...顾名思义被该注解标注的方法,会被 Room 的注解处理器识别,当作一个数据查询方法,至于具体的查询逻辑并不需要我们关心,我们只需要将 SQL 语句 作为参数,传入 @Query(...) 中即可。...我们看到,我们向其中传入了多个参数,包括:entities 以数组结构,标记一系列数据库中的表,这个例子中我们只有一个 User 表,所以只传入一个; version 数据库版本;exportSchema
var studentInfo: String 修饰函数 使用 @Ignore 注解标注构造函数后 , Room 框架就不会使用该构造方法了 ; 下面的 3 个构造函数中 , Room 框架 使用 constructor...} 3、定义 Dao 数据库访问对象接口 @Dao 注解 定义的 Dao 数据库访问对象接口 是一个 interface 接口 , 使用 @Dao 注解修饰该接口 ; /** * 数据库访问对象接口...(): List /** * 根据传入的 id 查询数据库表 * 在注解中使用 :id 调用参数中的 id: Int */ @Query...定义的 RoomDatabase 数据库实例类 是一个 抽象类 , 需要继承 RoomDatabase 抽象类 , 同时要使用 @Database 注解修饰 , @Database(entities...* 设置该数据类对应数据库中的一张数据表, 表名为 student * 该数据库表中的数据对应一个 Student 类实例对象 */ @Entity(tableName = "student")
Entity:表示数据库中的表。 DAO:包含用于访问数据库的方法。 应用使用 Room 数据库来获取与该数据库关联的数据访问对象 (DAO)。...,就是查询所有搜索历史返回的集合我用Flow修饰了。...Room 不知道表中有更新的数据是哪一个,因此它会重新触发 DAO 中定义的 query 操作。...数组,对应此数据库中的所有表 version 数据库版本号 注意: 如果您的应用在单个进程中运行,在实例化 AppDatabase 对象时应遵循单例设计模式。...room.expandProjection:配置 Room 以重写查询,使其顶部星形投影在展开后仅包含 DAO 方法返回类型中定义的列。 android { ...
JetPack提供了Room数据库,和GreenDAO等开源库一样,在SQLite做了封装 Room主要使用三个注解: 1.Entity:实体类,对应一张表 2.Dao:包含操作表的一些列方法 3.Database...需要满足:定义的类是一个继承RoomDatabase的抽象类,注解中定义包含实体类列表,包含一个没有参数的抽象方法并返回Dao对象 一、Room上手 首先添加依赖: implementation...' 定义一个实体类,在class上使用 @Entity注解 ,还需要一个构造方法,Room会根据这个构造将表里的数据转化为实体类,对于其他我们代码里使用的构造方法,可以使用@Ignore注解表示Room...、数据库版本、是否输出日志 使用单例模式时,构造方法不能私有化,因为Room内部会调用构造方法 定义获取Dao对象的抽象函数 package com.aruba.room; import android.content.Context...异常,使用fallbackToDestructiveMigration方法,出现异常时,会重新构造表,当然以前的数据会丢失 3.Schema文件 我们在使用@Database注解时exportSchema
导语 Room 持久性库在 SQLite 的基础上提供了一个抽象层,让用户能够在充分利用 SQLite 的强大功能的同时,获享更强健的数据库访问机制。 ? Room简介 ?...使用 @Database 注释的类应满足以下条件: 是扩展 RoomDatabase 的抽象类。 在注释中添加与数据库关联的实体列表。 包含具有 0 个参数且返回使用 @Dao 注释的类的抽象方法。...Entity:表示数据库中的表。 DAO:包含用于访问数据库的方法。 应用使用 Room 数据库来获取与该数据库关联的数据访问对象 (DAO)。...关于Dao的复用及数据库升级 从上面的创建我们可以看到增、删、改基本都是一样的,所以可以用泛型做一个简单的封装,这样别的类要写Dao时可以继承这个基类不用再改增、删、改了。...使用过程中,经常会遇到数据库升级的问题,在Room中使本地SQLITE库数据库升级可以用Migration方式,我们直接做一个新的类,对数据进行操作,也直接在原数据库上升级。
至于为何要使用本地数据库,自然是当用户无网络或者网络差的时候,能够更好的提高用户对我们App的体验。 添加依赖 在使用Room之前,我们还是要在项目中对其进行依赖添加。...对于Room的使用主要由三部分构成: Entity:标识数据库中的表结构 DAO: 标识提供获取数据库表中的数据方法 Database:标识所需要创建的数据库 以上三部分在代码中都是通过注释来实现,从而达到代码的精简...Room的强大之一是:它可以在编译时检测你的SQL语句是否编写正确,如果编写错误将导致编译失败。这样就可以避免App在运行时导致崩溃。这个读者可以自行测试一下。...当然也是同@Database来标明它是一个数据库。它接收两个参数,分别为entities与version,前者接收的类型是Class[]数组,内容为对于表的Class;后者是int的数据库版本号。...在ContactsDataBase中还需定义一个抽象方法,让它返回由@Dao注释的ContactsDao,即提供获取数据表的方法。本质的为数据库暴露操作数据表的入口。
初始化room,这里我与官方处理的方式略有差异根据我们的模块化方案,room初始化我们放置在:features:feature_common:common_room_db模块中@SuppressLint...根据我们的模块化方案,其中Entity放置在:features:feature_common:common_room_db模块中,Model类及转换类放置在data_xxxx模块中,依赖关系为,data_xxxxx...dao,room基本用法,不懂可以查看下上述的官网说明。...根据我们的模块化方案,dao存储在:features:feature_common:common_room_db模块中//这里注意,增删改查都可以使用@Query操作符,只需要在后边写上需要操作的语句即可...>}然后我们在data_xxxx模块中创建代理查询类,并提供将业务模型转为数据库模型&数据库模型转为业务模型的代理,方便使用。
通过注解的方式来进行数据库的配置,以及SQL的查询,并且在编译的过程中,会检查SQL以及数据库配置等的正确性,同时也支持外键、事务等。...Room使用 Gradle配置,在app的build.gradle中添加如下配置 dependencies { def room_version = "1.1.1" implementation..."android.arch.persistence.room:testing:$room_version" } 定义数据库 使用entities定义在数据库中存储的实体结构 使用version定义数据库版本...(数据库版本升级后续介绍) 在抽象类中,定义一个抽象方法提供DAO对象 @Database(entities = { UserData.class }, version = 1) public abstract...{ public abstract UserDataDao userDataDao(); } 在Build数据库时,添加Migration进行数据库升级 UserDatabase db = Room.databaseBuilder
1、POJO POJO(Plain Old Java Object)这种叫法是Martin Fowler、Rebecca Parsons和Josh MacKenzie在2000年的一次演讲的时候提出来的...它的方法命名,构造及行为必须符合特定的约定: 1、所有属性为private。 2、这个类必须有一个公共的缺省构造函数。即是提供无参数的构造器。...实现类一般用于操作数据库,如对数据库进行修改、添加、删除等操作,一般直接调用公共类DAO。 ...我们通过DAO将POJO持久化为PO,用PO组装出来VO、DTO。 总结下,我认为一个对象究竟是什么O要看具体环境,在不同的层、不同的应用场合,对象的身份也不一样,而且对象身份的转化也是很自然的。...BO: POJO在业务层的体现,对于业务操作来说,更多的是从业务上来包装对象,如一个User的BO,可能包括name, age, sex, privilege, group等,这些属性在数据库中可能会在多张表中
使用对应增删改查注解标识方法 @Database 声明数据库(需为abstract),该注解属性entities需声明该数据库中的所有表,version表示该数据库的版本,数据库中声明返回Dao实例的方法...使用流程 通过Room的静态方法databaseBuilder传入context,数据库的class对象,数据库的名称(db结尾)调用build函数就创建了数据库 数据类: @Entity(tableName...Dao,进行增删改查操作 2.降序升序:在databaseBuilder函数后添加迁移策略addMigrations,构造函数的两个版本对应迁移的版本,migrate函数是匹配对应策略后进行的操作 大致原理...疑问:Dao中只是定义了访问数据库的接口,数据库也只是个抽象类返回Dao实例的接口还没有实现?...在编译期间借助KAPT插件生成@Database标记的实现类,类名只是添加了一个后缀_Impl,而@Dao也会生成对应的_Impl后缀的实现类 查看Dao的实现类发现其每一个crud都是一个事物,并且在
在处理列或者表的重命名时,Room 无法明确发生了什么更改,此时可能有两种情况,是删除后新添加的?还是进行了重命名?处理列或者表的删除操作时也会有同样问题。...} } 完成 AutoMigrationSpec 的实现后,还需要将其添加到数据库定义时配置的 @AutoMigation 中,同时提供两个版本的数据库 schema,Auto Migration...在 Room 内部,如果存在自动迁移,它们将自动添加到需要运行和验证的迁移列表中。...使用全新关系查询功能 为了表示前面所示的音乐人与其歌曲之间的关系,我们现在可以编写一个简单的 DAO 方法,其返回类型为 Map,而我们需要做的仅仅是提供 @Query 和返回标记,Room 将为您处理其余的一切...支持查询回调 现在,Room 提供了一个通用 callback API RoomDatabase.QueryCallback,此 API 会在执行查询时被调用,这将非常有助于我们在 Debug 模式下记录日志
如果查询出来的列名和POJO中的属性名全部不一致,没有创建POJO对象。 只要查询出来的列名和POJO中的属性有一个一致,就会创建POJO对象。...(二)、输出POJO对象和POJO列表 不管是输出的POJO单个对象还是一个列表(List中存放POJO),在mapper.xml中ResultType指定的类型是一样的,但方法返回值类型不一样。...、if+set设置值 当update语句中没有使用if标签时,如果有一个参数为null,都会导致错误。...下面对属性进行简单的介绍: item:表示集合中每一个元素进行迭代时的别名。 index:指定一个名字,用于表示在迭代过程中每次迭代的位置。 open:表示以什么开始。...--根据roleId获取用户列表: 当数据库中的字段信息与对象的属性不一致时需要通过resultMap来映射 --> <!
如果想在数据库中存储这样的值,我们就需要通知Room如何将我们自定义的类型转换为原始类型。...,我又添加了createDate字段,这是日期类型,如果想在数据库中存储它,这时候我们就需要创建类型转换器。...如图,我们已经将Date插入到了数据库,并且通过查询拿出来。...除了将@TypeConverters放在RoomDatabase里面,还可以将它放在具体的Dao上面,但是这样只会影响到该Dao的方法。...通过@TypeConverters类型转换器,我们能够将非原始类型的值保存到数据库中。未完待续
领取专属 10元无门槛券
手把手带您无忧上云