Android Room从入门到放弃
来源:互联网 发布:网络广告创意图片 编辑:程序博客网 时间:2024/05/22 00:25
Android 2017 IO大会推出了官方数据库框架:Room。Room其实就只是对原生的SQLite API进行了一层封装。
简单使用:
- 和常规的ORM框架一样,让Entity对应数据库表,然后通过添加编译期注解来进行表和字段的配置,例如:
@Entitypublic class Student implements Serializable { @PrimaryKey public int id; @ColumnInfo(name = "student_name") public String name; @Embedded(prefix = "address_") public Address address;}
- 用抽象DAO类来定义数据库的CRUD操作,例如:
@Daopublic abstract class StudentDao { @Insert(onConflict = OnConflictStrategy.REPLACE) public abstract void insert(Student... students); @Delete public abstract void delete(Student... students); @Update public abstract void update(Student... students); @Query("DELETE FROM Student") public abstract void deleteAll();}
- AppDatabase对应数据库,同时用来提供DAO类
@Database(entities = {Student.class}, version = 1, exportSchema = false)public abstract class AppDatabase extends RoomDatabase{ public abstract StudentDao studentDao();}
- 调用范例
AppDatabase mDatabase = Room.databaseBuilder(this, AppDatabase.class, "app").addMigrations().build();StudentDao dao = mDatabase.studentDao();Student student = new Student();student.id = 111;students.add(student);
原理: 在编译时,使用annotationProcessor来解析被@Database和@Dao标注的类,在build/generated/source/apt里生成具体的Impl类,相比于SQLite API,一定程度上减少了我们创建表和部分CRUD书写的代码量。
优点:
1. 分层清晰,上手简单,代码相比于第三方也更加可靠
2. 非基于运行时注解,仅对SQLite API进行简单封装,效率没问题
3. 存储对象里嵌套对象时,可使用@Embedded注解进行自动拆分存储。Room会把被嵌套对象里的字段放置存储对象对应的表里,例如上例,Student表里不仅会有id和name字段,还会有address对象里的所有字段。这样就可以不用通过外键关联多表了。
缺点:
1. 查询和需要判断条件的删改都免不了要写SQL语句,虽然Room把语句拼写错误的提示提前到了编译时,但仍然需要关心表名、字段名等
2. 数据库升级无法自动且未提供友好API,同样需要写SQL语句,开发者手动写”ALTER table”在多表外键关联时容易出错。
阅读全文
0 0
- Android Room从入门到放弃
- Android从入门到放弃系列--目录
- android从入门到放弃2--ButterKnife
- Android从入门到放弃3-线程
- Android从入门到放弃4-Service
- Android插件化:从入门到放弃
- Android插件化:从入门到放弃
- Android插件化:从入门到放弃
- Android插件化:从入门到放弃
- Android插件化:从入门到放弃
- Android插件化:从入门到放弃
- 【Android 从入门到放弃】 ButterKnife 使用
- 发布 Android Library 到 JCenter 从入门到放弃
- Freemarker 从入门到放弃
- kmp从入门到放弃
- Dagger2从入门到放弃
- 推送 从入门到放弃
- 推送 从入门到放弃
- jquery事件委派
- java在web开发安全性方面的总结
- Mongodb与spring集成 实体映射
- PHP declare(ticks=N); 的作用(转多篇文章)
- Android 悬浮窗权限各机型各系统适配大全
- Android Room从入门到放弃
- 跨程序共享数据
- 文章标题
- Memcache的并发问题和利用CAS的解决方案
- 在ofbiz中从多个数据库获取数据
- Java获得汉字的二进制码
- 搭建redis集群
- 华为VRP命令行基础
- mysql导入大批量数据出现MySQL server has gone away的解决方法