JetPack开发笔记:Room数据库的详解与基础使用

本文介绍如何使用Android JetPack组件Room数据库,包括定义实体类、创建DAO及数据库类等关键步骤。

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数据库的数据库本身,表以及对数据库的操作:

    1. 数据库类,用于保存数据库并作为应用持久性数据底层连接的主要访问点。
      对应数据库本身。
    1. 数据实体,用于表示应用的数据库中的表。
      对应数据库中的表。
    1. 数据访问对象 (DAO),提供您的应用可用于查询、更新、插入和删除数据库中的数据的方法。
      对应具体的操作方法

在具体使用Room时,我们也需要具体实现这三个类,以帮助Room数据库创建,读写数据。

开始使用Room数据库

1.定义实体类

上面说到,数据实体对应的是数据库中的表,那么数据实体中的字段就对应的是表中每一列的数据,例如:


                
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值