JetPack之Room数据库基本使用与数据库升级

  • 为什么要使用Room数据库
  • Room数据库的基本使用
  • Room数据库的升级

简介

Android Jetpack自从成为谷歌官方架构之后,Room数据库逐渐替代了SQLite,GreenDao成为最主流的数据库ORM框架。Room数据不仅简化了SQLlite数据库的使用门槛,还可以结合LiveData使用。

Room是SQLite数据库的抽象。

Room数据库主要包括三个角色

  1. Entity :表示数据库中的表
  2. Dao:提供数据库增,删,改,查的方法。
  3. DataBase:数据持久化存储底层链接的访问入口。

基本使用

  1. 数据表

定义一张表名为student_table的数据表,使用@Entity注解。主键使用@PrimaryKey修饰,autoGenerate 是否自增。使用@ColumnInfo注解定义字段名,如果不使用注解则默认为实体类的字段名。注意:如果我们在实体类中定义的字段不想存入表中,我们可以使用@Ignore注解修饰该字段。

  1. 数据库访问对象Dao

Room数据库使用了APT技术,我们只需要定义接口或抽象类,使用@Dao注解修饰,编译器会自动生成实现类。

我们定义了增,删,改,查的四个方法。其中查询使用了SQL语句,开发者可根据不同的查询条件进行数据筛选。

  1. 数据库类

定义StudentDataBase抽象类并使用@Database注解修饰,指定数据表entity以及版本号等信息。

  1. ViewModel中的增删改查操作。
  1. 操作结果

数据库迁移

当在表中新增加一个列字段 height。为了兼容旧版本数据库,需要数据库增量迁移。

  1. 使用fallbackToDestructiveMigration() 强制迁移,可能会导致数据丢失。
  1. 手动迁移。(自动迁移有风险,不推荐使用,本文暂不介绍)

如果迁移数据结构比较复杂,推荐使用手动迁移,使用自定义Migration类来实现。

相关推荐
菠萝加点糖16 分钟前
Android 使用MediaMuxer+MediaCodec编码MP4视频
android·音视频·编码
雨白1 小时前
手写 MaterialEditText:实现浮动标签(Floating Label)效果
android
CYRUS_STUDIO2 小时前
使用 readelf 分析 so 文件:ELF 结构解析全攻略
android·linux·逆向
小强开学前4 小时前
WebView 静态页面秒加载方案要点
android·webview
纽马约4 小时前
Android Room的使用详解
android
游戏开发爱好者85 小时前
基于uni-app的iOS应用上架,从打包到分发的全流程
android·ios·小程序·https·uni-app·iphone·webview
深盾科技5 小时前
Android Keystore签名文件详解与安全防护
android·安全·gitee
安卓开发者5 小时前
Android Glide插件化开发实战:模块化加载与自定义扩展
android·glide
夏天的味道٥10 小时前
MySQL explain命令的作用
android·mysql·adb