Room介绍以及不使用SQLite的原因

Room 在 SQLite 上提供了一个抽象层,以便在充分利用 SQLite 的强大功能的同时,能够流畅地访问数据库。

处理大量结构化数据的应用可极大地受益于在本地保留这些数据。最常见的用例是缓存相关数据。这样,当设备无法访问网络时,用户仍可在离线状态下浏览相应内容。设备重新连接到网络后,用户发起的所有内容更改都会同步到服务器。

由于 Room 负责为您处理这些问题,因此我们强烈建议您使用 Room(而不是 SQLite)。不过,如果您想直接使用 SQLite API,请参阅使用 SQLite 保存数据

Room 包含 3 个主要组件:

  • 数据库:包含数据库持有者,并作为应用已保留的持久关系型数据的底层连接的主要接入点。
  • 使用 @Database 注释的类应满足以下条件:
    • 是扩展 RoomDatabase 的抽象类。
    • 在注释中添加与数据库关联的实体列表。
    • 包含具有 0 个参数且返回使用 @Dao 注释的类的抽象方法。

在运行时,您可以通过调用 Room.databaseBuilder()Room.inMemoryDatabaseBuilder() 获取 Database 的实例。

  • Entity:表示数据库中的表。
  • DAO:包含用于访问数据库的方法。

应用使用 Room 数据库来获取与该数据库关联的数据访问对象 (DAO)。然后,应用使用每个 DAO 从数据库中获取实体,然后再将对这些实体的所有更改保存回数据库中。 最后,应用使用实体来获取和设置与数据库中的表列相对应的值。

Room 不同组件之间的关系如图所示:

环境配置

如需在应用中使用 Room,请将以下依赖项添加到应用的 build.gradle 文件。

  1. dependencies {
  2. def room_version = "2.4.1"
  3. implementation "androidx.room:room-runtime:$room_version"
  4. annotationProcessor "androidx.room:room-compiler:$room_version"
  5. // optional - RxJava2 support for Room
  6. implementation "androidx.room:room-rxjava2:$room_version"
  7. // optional - RxJava3 support for Room
  8. implementation "androidx.room:room-rxjava3:$room_version"
  9. // optional - Guava support for Room, including Optional and ListenableFuture
  10. implementation "androidx.room:room-guava:$room_version"
  11. // optional - Test helpers
  12. testImplementation "androidx.room:room-testing:$room_version"
  13. // optional - Paging 3 Integration
  14. implementation "androidx.room:room-paging:2.4.1"
  15. }

创建User类

  1. @Entity
  2. public class User {
  3. @PrimaryKey
  4. public int uid;
  5. @ColumnInfo(name = "first_name")
  6. public String firstName;
  7. @ColumnInfo(name = "last_name")
  8. public String lastName;
  9. }

创建UserDao

  1. @Dao
  2. public interface UserDao {
  3. @Query("SELECT * FROM user")
  4. List<User> getAll();
  5. @Query("SELECT * FROM user WHERE uid IN (:userIds)")
  6. List<User> loadAllByIds(int[] userIds);
  7. @Query("SELECT * FROM user WHERE first_name LIKE :first AND " +
  8. "last_name LIKE :last LIMIT 1")
  9. User findByName(String first, String last);
  10. @Insert
  11. void insertAll(User... users);
  12. @Delete
  13. void delete(User user);
  14. }

创建AppDatabase

  1. @Database(entities = {User.class}, version = 1)
  2. public abstract class AppDatabase extends RoomDatabase {
  3. public abstract UserDao userDao();
  4. }

创建上述文件后,您可以使用以下代码获取已创建的数据库的实例:

  1. AppDatabase db = Room.databaseBuilder(getApplicationContext(),
  2. AppDatabase.class, "database-name").build();

数据库测试

创建两个EditText控件用来输入first_namelast_name

创建两个按钮用来控制数据库中数据输入与输出

将输出结果显示到TextView中

  1. public class DatabaseTestActivity extends AppCompatActivity {
  2. private UserDao userDao;
  3. private AppDatabase db;
  4. private EditText ed_1,ed_2;
  5. private Button btn_1,btn_2;
  6. private TextView tv;
  7. @Override
  8. protected void onCreate(Bundle savedInstanceState) {
  9. super.onCreate(savedInstanceState);
  10. setContentView(R.layout.activity_database_test);
  11. db = Room.databaseBuilder(this,AppDatabase.class,"test").allowMainThreadQueries().build();
  12. userDao = db.userDao();
  13. ed_1 = findViewById(R.id.ed_1);
  14. ed_2 = findViewById(R.id.ed_2);
  15. btn_1 = findViewById(R.id.ti);
  16. btn_2 = findViewById(R.id.td);
  17. tv = findViewById(R.id.tv);
  18. btn_1.setOnClickListener(new View.OnClickListener() {
  19. @Override
  20. public void onClick(View view) {
  21. String s = ed_1.getText().toString();
  22. String s1 = ed_2.getText().toString();
  23. User user = new User();
  24. user.firstName=s;
  25. user.lastName=s1;
  26. user.uid=1;
  27. userDao.insertAll(user);
  28. }
  29. });
  30. btn_2.setOnClickListener(new View.OnClickListener() {
  31. @Override
  32. public void onClick(View view) {
  33. List<User> all = userDao.getAll();
  34. tv.setText(all.toString());
  35. }
  36. });
  37. }
  38. @Override
  39. protected void onDestroy() {
  40. super.onDestroy();
  41. db.close();
  42. }
  43. }

效果展示:

Android开发----使用 Room 将数据保存到本地数据库的更多相关文章

  1. Android开发:SharedPreferences 存储数据、获取数据

    Android开发:SharedPreferences 存储数据.获取数据 email:chentravelling@163.com 开发环境:win7 64位,Android Studio. 关于S ...

  2. pandas数据保存至Mysql数据库

    pandas数据保存至Mysql数据库 import pandas as pd from sqlalchemy import create_engine host = '127.0.0.1' port ...

  3. Windows Phone开发(48):不可或缺的本地数据库

    原文:Windows Phone开发(48):不可或缺的本地数据库 也许WP7的时候,是想着让云服务露两手,故似乎并不支持本地数据库,所有数据都上传上"云"数据库中.不过呢,在SD ...

  4. Android开发学习之路--数据持久化之初体验

    上班第一天,虽然工作上处于酱油模式,但是学习上依旧不能拉下,接着学习android开发吧,这里学习数据持久化的 知识. 其实数据持久化就是数据可以保存起来,一般我们保存数据都是以文件,或者数据库的形式 ...

  5. android开发 socket接收图片并保存

    逻辑:接收到socket之后需要将socket发送的图片数据保存下来并通知handler更新界面 关键代码: public void readImage(Socket socket) { try { ...

  6. MTK Android Android数据保存到系统数据库

    如果有留意Android中系统设置Settings里面的源码,你会发现代码中频繁用到了Settings.System操作,该类通过键值对的形式,将一些特定的值以全局的模式保存到Setting的数据库中 ...

  7. pyhton 从web获取json数据 保存到本地然后再读取

    从web中获取json数据直接进行处理总认为太慢.主要是从web中获取获取数据的过程有点慢. 所以就在想 假设先利用空暇时间把json数据获取并保存到本地,然后再从本地文件里读取和操作.应该就要快非常 ...

  8. python爬虫:将数据保存到本地

    一.python语句存储 1.with open()语句 with open(name,mode,encoding) as file: file.write() name:包含文件名称的字符串; mo ...

  9. 一文搞定scrapy爬取众多知名技术博客文章保存到本地数据库,包含:cnblog、csdn、51cto、itpub、jobbole、oschina等

    本文旨在通过爬取一系列博客网站技术文章的实践,介绍一下scrapy这个python语言中强大的整站爬虫框架的使用.各位童鞋可不要用来干坏事哦,这些技术博客平台也是为了让我们大家更方便的交流.学习.提高 ...

随机推荐

  1. 【LeetCode】1579. 保证图可完全遍历 Remove Max Number of Edges to Keep Graph Fully Traversable

    作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题思路 并查集 代码 欢迎加入组织 日期 题目地址:https ...

  2. 【LeetCode】116. 填充每个节点的下一个右侧节点指针 Populating Next Right Pointers in Each Node 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 递归 日期 题目地址:https://leetcode ...

  3. D. Ability To Convert

    http://codeforces.com/contest/758/problem/D D. Ability To Convert time limit per test 1 second memor ...

  4. 【LeetCode】814. Binary Tree Pruning 解题报告(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 后序遍历 日期 题目地址:https://leetc ...

  5. 比赛难度(HDU4546)

    比赛难度 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total Submis ...

  6. XSLT映射文件函数

    任何的编程语言或者是SQL语句都有内置的函数或方法,而强大灵活的xslt技术也是如此.熟练掌握XSLT的常用函数的用法,XSLT的应用将变得如此轻松,你会发现XSLT比想象中还要牛!以下是xslt数值 ...

  7. 第十个知识点:RSA和强RSA问题有什么区别?

    第十个知识点:RSA和强RSA问题有什么区别 这个密码学52件事数学知识的第一篇,也是整个系列的第10篇.这篇介绍了RSA问题和Strong-RSA问题,指出了这两种问题的不同之处. 密码学严重依赖于 ...

  8. Java基础(八)——IO流5_其他流

    一.其他 1.System.in.System.out(标准输入.输出流) System.in:标准的输入流,默认从键盘输入. System.out:标准的输出流,默认从控制台输出. 改变标准输入输出 ...

  9. Kubernetes-Kuboard

    前言 本篇是Kubernetes第十五篇,大家一定要把环境搭建起来,看是解决不了问题的,必须实战. Kubernetes系列文章: Kubernetes介绍 Kubernetes环境搭建 Kubern ...

  10. centos一步一步搭建tendermint

    一.必要条件 1.安装go 请根据官方文档安装:https://golang.org/doc/install 要特别注意的是: /etc/profile 添加以下内容: export GOPATH=/ ...