Android使用Room数据库解决本地持久化的操作

 更新时间:2024年09月18日 09:33:07   作者:吃汉堡吃到饱  
Room 是一个持久性库,属于 Android Jetpack 的一部分,Room 是 SQLite 数据库之上的一个抽象层,Room 并不直接使用 SQLite,而是负责简化数据库设置和配置以及与数据库交互方面的琐碎工作,本文介绍了Android使用Room数据库解决本地持久化的操作,需要的朋友可以参考下

Room概述

Room 是一个持久性库,属于 Android Jetpack 的一部分。

Room 是 SQLite 数据库之上的一个抽象层。Room 并不直接使用 SQLite,而是负责简化数据库设置和配置以及与数据库交互方面的琐碎工作。此外,Room 还提供 SQLite 语句的编译时检查。

Room主要组件

Room 包含三个主要组件:

  • 数据实体表示应用的数据库中的表。数据实体用于更新表中的行所存储的数据以及创建新行供插入。
  • 数据访问对象 (DAO) 提供应用在数据库中检索、更新、插入和删除数据所用的方法。
  • 数据库类持有数据库,并且是应用数据库底层连接的主要访问点。数据库类为应用提供与该数据库关联的 DAO 的实例。

Room各组件之间协同工作图例

img

添加Room库

在build.gradle文件中添加依赖:

dependencies {
        //Room
        def room_version = "2.5.0"
        implementation "androidx.room:room-runtime:$room_version"
        annotationProcessor "androidx.room:room-compiler:$room_version"
}

版本号请查阅官方文档:

https://developer.android.google.cn/jetpack/androidx/releases/room?hl=zh_cn#groovy

创建Item 实体—Entity

实体类定义了一个表,每个实例都是表的某一行。用映射的方式,实体类告知Room数据库,它应如何呈现数据库中的信息并与之交互。

image-20240917201608505

@Entity 注解用于将某个类标记为数据库实体类。对于每个实体类,系统都会创建一个数据库表来保存相关项。存储在数据库中的每个实体实例必须有一个主键,用于唯一标识数据库表中的每个记录/条目。主键一旦赋值就不能修改,只要它还存在于数据库中,它就表示相应的实体对象。

在类之前加上 @Entity 注解来标识数据库的实体,编译时,系统便会根据这个类的设定来创建数据库。

@Entity()
public class Word{

}

如果Entity()的参数为空,系统在创建数据库时,会把类名作为数据库的表名,如果要自定义表名,可以直接在Entity()里输入参数:

@Entity(tableName = "yourTableName")

接下来,我们应该添加:

  • 数据库的元素
  • 主键:每一个实体至少定义一个字段作为主键。可以将@PrimaryKey的autoGenerate属性设置为true来设置自动id。如果实体有一个复合的主键,可以使用 @Entity的primaryKeys属性来指定主键。

元素包括:

  • id
  • word
  • chineseMearning
@PrimaryKey(autoGenerate = true)
private  int id;
@ColumnInfo(name = "english_word")
private String word;
@ColumnInfo(name = "chinese_mearning")
private String chineseMeaning;

再加上几个get/set方法就定义完成了!

创建item 数据访问对象—Dao

新建一个MyDao对象的接口作为数据库操作的接口,在这个接口中,我们定义数据库的增删改查操作,在此之前,我们需要用 @Dao 来标记这个类为Dao类:

例如:

@Dao    //Database access object
public interface WordDao {
    @Insertvoid  
    insertWords(Word... words);
    
    @Updateint 
    updateWords(Word... words);
    
    @Deletevoid 
    deleteWords(Word...words);
}

如果我们要使用SQL语句,我们可以这么写:

@Dao    //Database access object
public interface WordDao {
    @Insertvoid  
    insertWords(Word... words);
    
    @Updateint 
    updateWords(Word... words);
    
    @Deletevoid 
    deleteWords(Word...words);
    
    @Query("DELETE FROM WORD")
    void deleteWords();
    
    @Query("SELECT * FROM WORD ORDER BY ID DESC")
    List<Word> getAllWords();
}

创建数据库实例—Database

我们将创建database类,通过继承改写room的database,把word.classwordDao.class联系在一起,组成一个完整的数据库。

在同一个位置新建一个WordDatabase的数据库,父类是androidx.room.RoomDatabase,为abstract类型。

我们通过@Database()来标记这个类为database类,在它的参数中我们可以定义:

  • entities:传入所有Entity的class对象;
  • version:数据库版本号。
  • exportSchema:设置是否导出数据库schema,默认为true,需要在build.gradle中设置:

当数据库发生改变时,数据库版本号会接着改变,以便更好的进行备份恢复,这里我们用不到,就随便设计一个值。

上面的Database()中,我们已经把Entity连接到了database中,在Dao类中,我们需要把wordDao类连接到数据库中,我们就需要实例化一个WordDao类:

@Database(entities = {Word.class},version = 1, exportSchema = false)
public abstract class WordDatabase extends RoomDatabase {
    public abstract WordDao getWordDao();
}

使用Room数据库

获取AppDatabase实例:

AppDatabase wordDatabase = Room.databaseBuilder(getApplicationContext(),AppDatabase.class, "user.db").build();

使用Room可以参考:

wordDao = wordDatabase.getWordDao();  // new a dao

List<Word> list = wordDao.getAllWords();  //get all data from database with sql: select * from word

结语

以上就是Android使用Room数据库解决本地持久化的操作的详细内容,更多关于Android Room本地持久化的资料请关注脚本之家其它相关文章!

相关文章

  • Android中的指纹识别demo开发实例

    Android中的指纹识别demo开发实例

    这篇文章主要介绍了Android中的指纹识别demo开发实例的相关知识,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-09-09
  • Android viewpage实现可控制的禁止滑动

    Android viewpage实现可控制的禁止滑动

    这篇文章主要为大家详细介绍了Android viewpage实现可控制的禁止滑动,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • android侧滑菜单控件DrawerLayout使用方法详解

    android侧滑菜单控件DrawerLayout使用方法详解

    这篇文章主要为大家详细介绍了android侧滑菜单控件DrawerLayout的使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-12-12
  • Android实现APP秒表功能

    Android实现APP秒表功能

    这篇文章主要为大家详细介绍了Android实现APP秒表功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-09-09
  • Android自定义view圆并随手指移动

    Android自定义view圆并随手指移动

    这篇文章主要为大家详细介绍了Android自定义view圆并随手指移动,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • Android仿京东快报无限轮播效果

    Android仿京东快报无限轮播效果

    这篇文章主要为大家详细介绍了Android仿京东快报无限轮播效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-06-06
  • Android 高仿QQ图片选择器

    Android 高仿QQ图片选择器

    这篇文章主要介绍了Android 高仿QQ图片选择器的实现思路,本文介绍的非常详细,具有参考借鉴价值,感兴趣的朋友一起看看吧
    2016-09-09
  • 浅谈EventBus

    浅谈EventBus

    EventBus是一款针对Android优化的发布/订阅事件总线。主要功能是替代Intent,Handler,BroadCast在Fragment,Activity,Service。本文对其实现原理进行系统介绍,有需要的朋友可以看下
    2016-12-12
  • Android获取本机各种类型文件的方法

    Android获取本机各种类型文件的方法

    这篇文章主要为大家详细介绍了Android获取本机各种类型文件的方法,包括音乐、视频、图片、文档等,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • Android实现屏幕截图并保存截图到指定文件

    Android实现屏幕截图并保存截图到指定文件

    这篇文章主要为大家详细介绍了Android实现屏幕截图并保存截取图片到指定文件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-10-10

最新评论