JetPack开发笔记:Room数据库的详解与基础使用
简介:
Android开发中我们常常会用到持久化数据保存手段,即将一些数据保存到本地。
其中比较常用的有两种:
- 1.通过SharedPreferences这种轻量化手段,利用键值对存储一些关系并不复杂的数据。
- 2.通过Android内置的SQLite数据库进行关系较为复杂的数据的存储。
Android提供了API帮助我们操作SQLite数据库,但是这种方法较为复杂。而利用JetPack中
的Room数据库,我们可以较为方便地操作SQLite数据库。
Room 持久性库在 SQLite 上提供了一个抽象层,以便在充分利用 SQLite 的强大功能的同时,能够流畅地访问数据库。具体来说,Room 具有以下优势:
- 1.针对 SQL 查询的编译时验证。
- 2.可最大限度减少重复和容易出错的样板代码的方便注解。
- 3.简化了数据库迁移路径。

出于这些方面的考虑,现在Google官方已经建议我们使用Room,而不是直接使用SQLite
API
添加依赖:
我们需要在应用的build.gradle文件下添加几行依赖:
implementation 'androidx.room:room-common:2.3.0'
implementation 'androidx.room:room-runtime:2.4.3'
annotationProcessor "androidx.room:room-compiler:2.4.3"
Room数据库的三个主要组件:
Room的三个主要组件分别对应SQLite数据库的数据库本身,表以及对数据库的操作:
-
- 数据库类,用于保存数据库并作为应用持久性数据底层连接的主要访问点。
对应数据库本身。
- 数据库类,用于保存数据库并作为应用持久性数据底层连接的主要访问点。
-
- 数据实体,用于表示应用的数据库中的表。
对应数据库中的表。
- 数据实体,用于表示应用的数据库中的表。
-
- 数据访问对象 (DAO),提供您的应用可用于查询、更新、插入和删除数据库中的数据的方法。
对应具体的操作方法
- 数据访问对象 (DAO),提供您的应用可用于查询、更新、插入和删除数据库中的数据的方法。
在具体使用Room时,我们也需要具体实现这三个类,以帮助Room数据库创建,读写数据。
开始使用Room数据库
1.定义实体类
上面说到,数据实体对应的是数据库中的表,那么数据实体中的字段就对应的是表中每一列的数据,例如:

本文介绍如何使用Android JetPack组件Room数据库,包括定义实体类、创建DAO及数据库类等关键步骤。
最低0.47元/天 解锁文章
713





