IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Android Room的简单使用 -> 正文阅读

[大数据]Android Room的简单使用

Room简单使用

Room是一个持久性数据库,Room持久层库在SQLite上提供了一个抽象层,以便充分利用SQLite的强大功能同时,能够流畅地访问数据库,具有以下优势:

  • 针对SQL查询的编译时验证
  • 可最大限度减少重复和容易出错的样板代码的方便注解
  • 简化了数据库迁移路径

Room的三个部分

  • 数据库:用于保存数据库,并作为应用持久性数据底层连接的主要访问
  • 数据实体:用于表示数据库中的表
  • 数据访问对象(DAO):用于增删改查的数据方法

添加依赖

dependencies {
    def room_version = "2.4.2"

    implementation "androidx.room:room-runtime:$room_version"
    annotationProcessor "androidx.room:room-compiler:$room_version"

    // optional - RxJava2 support for Room
    implementation "androidx.room:room-rxjava2:$room_version"

    // optional - RxJava3 support for Room
    implementation "androidx.room:room-rxjava3:$room_version"

    // optional - Guava support for Room, including Optional and ListenableFuture
    implementation "androidx.room:room-guava:$room_version"

    // optional - Test helpers
    testImplementation "androidx.room:room-testing:$room_version"

    // optional - Paging 3 Integration
    implementation "androidx.room:room-paging:2.5.0-alpha01"
}

创建数据实体-即数据表

  • @Entity(tableName = “表名”):设置表名
  • @PrimaryKey(autoGenerate = false):当设置为true,让sqlite生成唯一的ID(即添加一个主键)
  • @Entity(primaryKeys = {“username”, “age”}):添加多个主键
  • @Ignore:忽略某个字段
//指定表名,默认情况下表名为类的名字,可使用tableName指定表名
@Entity
public class User {
    //指定id为主键,并自增
    @PrimaryKey(autoGenerate = true)
    public int id;

    //表示这个字段为一列,默认情况下类名为列名,也可以使用name属性指定列名
    @ColumnInfo(name = "username")
    public String username;

    @ColumnInfo(name = "age")
    public int age;
    
    //忽略这个字段
    @Ignore
    Bitmap image;
}

注意:SQLite的表名和列名不区分大小写

创建数据访问对象(DAO)-即访问数据库的方法

  • @DAO:指定数据访问对象
  • @Insert:插入数据
  • @Delete:删除数据
  • @Update:更新数据
  • @Query:查询数据
//指定数据访问对象DAO
@Dao
public interface UserDao {

    //插入数据
    @Insert
    void insert(User user);

    //删除数据
    @Delete
    void delete(User user);

    //更新数据
    @Update
    void update(User user);
    
    //获取所有用户数据
    @Query("select * from user")
    List<User> getUserAll();

    //查找指定的数据
    @Query("select * from user where username = :username and age = :age")
    List<User> getUserInfo(String username, int age);
}

创建数据库类

//指定数据实体类和版本号
@Database(entities = {User.class}, version = 1)
public abstract class AppDatabase extends RoomDatabase {
    //提供返回一个数据访问对象的方法
    public abstract UserDao userDao();
}

创建并使用

AppDatabase database = Room.databaseBuilder(getApplicationContext(), AppDatabase.class, "test.db").build();
UserDao userDao = database.userDao();
List<User> userDataAll = userDao.getUserAll();
for (User user : userDataAll) {
    Log.e("TAG", "id: " + user.id);
    Log.e("TAG", "username: " + user.username);
    Log.e("TAG", "age: " + user.age);
}
  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-04-04 12:18:09  更:2022-04-04 12:21:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 16:04:35-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码