一、使用

1、build.gradle引入

```
compile "android.arch.persistence.room:runtime:1.0.0"
annotationProcessor 'android.arch.persistence.room:compiler:1.0.0'
```

如果少了第二行引入,会报错:

``` Caused by: java.lang.RuntimeException: cannot find implementation for com.hy.room.HyDatabase. HyDatabase_Impl does not exist ```

2、新建一个实体类

```
@Entity(indices = {@Index(value = "firstName", unique = true)})
public class User {

  1. @PrimaryKey(autoGenerate = true)
  2. public int id;
  3. public String firstName;
  4. public String lastName;
  5. public int age;
  6. @Ignore
  7. private Bitmap bitmap;
  8. @Embedded
  9. public Address address;

}

  1. 3、建立Dao类接口
  2. <p></p>

@Dao

public interface UserDao {

  1. @Insert
  2. public long[] insertUsers(User... users);
  3. @Insert
  4. public void insertUserList(List&lt;User&gt; users);
  5. @Update
  6. public void updateUsers(User... users);
  7. @Delete
  8. public void deleteUsers(User... users);
  9. @Query("select * from User")
  10. public List&lt;User&gt; searchAllUsers();
  11. @Query("select * from User where :age &gt; 18")
  12. public List&lt;User&gt; searchUsersByAge(int age);
  13. @Query("select firstName,age from user")
  14. public List&lt;SimpleUser&gt; searchAllSimpleUsers();
  15. @Query("select * from User where firstName like :name limit 1")
  16. public User searchUserByName(String name);

}

  1. 4、建立继承RoomDatabase的数据库管理虚类
  2. <p></p>
  1. @Database(entities = {User.class}, version = 1)
  2. public abstract class HyDatabase extends RoomDatabase {
  3. public abstract UserDao userDao();
  4. }
  1. 5、初始化数据库
  2. <p></p>
  1. HyDatabase database = Room.databaseBuilder(this, HyDatabase.class, "room.db").build();
  1. 6、操作举例(与RxJava配合使用)
  2. <p></p>
  1. Observable.create(new ObservableOnSubscribe&lt;String&gt;() {
  2. @Override
  3. public void subscribe(ObservableEmitter&lt;String&gt; e) throws Exception {
  4. List&lt;User&gt; users = database.userDao().searchAllUsers();
  5. e.onNext(new Gson().toJson(users));
  6. }
  7. }).subscribeOn(Schedulers.io())
  8. .observeOn(AndroidSchedulers.mainThread())
  9. .subscribe(new Consumer&lt;String&gt;() {
  10. @Override
  11. public void accept(String s) throws Exception {
  12. textView.setText(s);
  13. }
  14. });
  1. <p>子线程中查询出所有的用户(主线程操作数据库会报错),用Gson转换成json格式的字符串,主线程中再显示出来。</p>
  2. <p><br /></p>
  3. <p></p>
  4. <h3><strong>二、数据库升级</strong></h3>
  5. 1、新建要增加实体类。
  6. <p></p>
  7. <p>2、在database中entities注解加入新增的实体类,同时版本号加一。</p>
  8. <p>3、初始化数据库的地方增加addMigrations()方法,实现Migration类,例如:</p>
  9. <p></p>
  1. HyDatabase database = Room.databaseBuilder(this, HyDatabase.class, "room.db")
  2. .addMigrations(migration)
  3. .build();

  1. <p></p>
  1. private Migration migration = new Migration(1,2) {
  2. @Override
  3. public void migrate(@NonNull SupportSQLiteDatabase database) {
  4. database.execSQL("CREATE TABLE `Book` (`id` INTEGER, "
  5. + "`name` TEXT, `owner` INTEGER, PRIMARY KEY(`id`))");
  6. }
  7. };
  1. 表示从版本1升级到版本2,手动增加新增的表的sql。<br /><br /><h3><strong>三、总结</strong></h3>
  2. <p>优点:</p>
  3. <p>1、从上面例子可以看出,操作很简单,不需要像以前一样,从SqlLite查询出数据,再一个个属性装配到实体类中。</p>
  4. <p>2、增删改查操作十分简便,只需要一个注解就搞定。<br /></p>
  5. <p>缺点:</p>
  6. <p>1、不能用Android Debug Database在线查看数据库?</p>
  7. <p>2、不能配置模糊查询条件?</p>
  8. <p>3、数据库升级无法自动且未提供友好API,同样需要手写SQL语句,同时必须保证手写的SQL语句与创建的实体类中的注解完全一致,不然会报错,例如:</p>
  9. <p></p>

java.lang.IllegalStateException: Migration didn't properly handle Book(com.hy.room.Book).

Expected:TableInfo{name='Book', columns={name=Column{name='name', type='TEXT', notNull=false, primaryKeyPosition=0}, owner=Column{name='owner', type='INTEGER', notNull=true, primaryKeyPosition=0}, id=Column{name='id', type='INTEGER', notNull=true, primaryKeyPosition=1}}, foreignKeys=[], indices=[]}

Found:

TableInfo{name='Book', columns={name=Column{name='name', type='TEXT', notNull=false, primaryKeyPosition=0}, owner=Column{name='owner', type='INTEGER', notNull=false, primaryKeyPosition=0}, id=Column{name='id', type='INTEGER', notNull=false, primaryKeyPosition=1}}, foreignKeys=[], indices=[]}

  1. <p><br /></p>
  2. <h3>四、神坑</h3>
  3. <p>1、报错</p>
  4. <p></p>

java.lang.RuntimeException: cannot find implementation for com.hiten.base.db.DbHoc. DbHoc_Impl does not exist

at android.arch.persistence.room.Room.getGeneratedImplementation(Room.java:92)

at android.arch.persistence.room.RoomDatabase$Builder.build(RoomDatabase.java:454)

at com.hiten.base.manager.ManagerDb.init(ManagerDb.java:21)

at com.hiten.base.ApplicationHoc.onCreate(ApplicationHoc.java:52)

  1. log说找不到_impl实现类,看来是编译的问题。查看配置和代码,发现都没有问题,经过几个小时的尝试,终于发现还是配置的问题,问题出在这行:
  2. <p></p>
  1. annotationProcessor "android.arch.persistence.room:compiler:1.0.0"
  1. 我们所有的第三方引入都在third这个module里面,然后在其他module写业务代码,上面那行代码只配置在thrid上面,导致执行的module没有运行编译room的代码,所以自然没有生成实现类。在使用roommodule也要加上上面那行代码。
  2. <p><br /></p>
  3. <h3>参考:</h3>
  4. <p><a href="https://developer.android.com/training/data-storage/room/index.html">官方文档(需翻墙)</a><br /></p>
  5. <p><a href="http://blog.csdn.net/hubinqiang/article/details/73012353">谷歌官方Android应用架构库——Room 持久化库</a><br /></p>
  6. </div>
  7. </div>
  8. </article>

Android Room框架学习笔记的更多相关文章

  1. phalcon(费尔康)框架学习笔记

    phalcon(费尔康)框架学习笔记 http://www.qixing318.com/article/phalcon-framework-to-study-notes.html 目录结构   pha ...

  2. Yii框架学习笔记(二)将html前端模板整合到框架中

    选择Yii 2.0版本框架的7个理由 http://blog.chedushi.com/archives/8988 刚接触Yii谈一下对Yii框架的看法和感受 http://bbs.csdn.net/ ...

  3. JavaSE中Collection集合框架学习笔记(2)——拒绝重复内容的Set和支持队列操作的Queue

    前言:俗话说“金三银四铜五”,不知道我要在这段时间找工作会不会很艰难.不管了,工作三年之后就当给自己放个暑假. 面试当中Collection(集合)是基础重点.我在网上看了几篇讲Collection的 ...

  4. JavaSE中Collection集合框架学习笔记(3)——遍历对象的Iterator和收集对象后的排序

    前言:暑期应该开始了,因为小区对面的小学这两天早上都没有像以往那样一到七八点钟就人声喧闹.车水马龙. 前两篇文章介绍了Collection框架的主要接口和常用类,例如List.Set.Queue,和A ...

  5. JavaSE中Map框架学习笔记

    前言:最近几天都在生病,退烧之后身体虚弱.头疼.在床上躺了几天,什么事情都干不了.接下来这段时间,要好好加快进度才好. 前面用了三篇文章的篇幅学习了Collection框架的相关内容,而Map框架相对 ...

  6. JavaSE中线程与并行API框架学习笔记1——线程是什么?

    前言:虽然工作了三年,但是几乎没有使用到多线程之类的内容.这其实是工作与学习的矛盾.我们在公司上班,很多时候都只是在处理业务代码,很少接触底层技术. 可是你不可能一辈子都写业务代码,而且跳槽之后新单位 ...

  7. JavaSE中线程与并行API框架学习笔记——线程为什么会不安全?

    前言:休整一个多月之后,终于开始投简历了.这段时间休息了一阵子,又病了几天,真正用来复习准备的时间其实并不多.说实话,心里不是非常有底气. 这可能是学生时代遗留的思维惯性--总想着做好万全准备才去做事 ...

  8. scrapy爬虫框架学习笔记(一)

    scrapy爬虫框架学习笔记(一) 1.安装scrapy pip install scrapy 2.新建工程: (1)打开命令行模式 (2)进入要新建工程的目录 (3)运行命令: scrapy sta ...

  9. Android安装器学习笔记(一)

    Android安装器学习笔记(一) 一.Android应用的四种安装方式: 1.通过系统应用PackageInstaller.apk进行安装,安装过程中会让用户确认 2.系统程序安装:在开机的时候自动 ...

随机推荐

  1. mysql 开发基础系列18 存储过程和函数(下)

    1. 光标的使用(游标) 在存储过程和函数中可以使用光标对结果集进行循环的处理,光标使用包括光标的声明,open ,fetch,close. 下面在存储过程中使用一个光标, 这个举例中光标里的逻辑不重 ...

  2. 基于Electron+.NET Core的前后端分离的跨平台桌面应用

    Web做界面比原生桌面界面开发速度真心要快很多,而且组件也多. 分析: 1..NET Core和Electron都是跨平台的. 2.NET Core做后端很方便,但是没有GUI,Electron做桌面 ...

  3. 前端测试框架Jest系列教程 -- Expect(验证)

    写在前面 在编写测试时,我们通常需要检查值是否满足某些条件,Jest中提供的expect允许你访问很多“Matchers”,这些“匹配器”允许您验证不同的东西. Expect 可以验证什么 Jest中 ...

  4. MySQL中字段字符集不同导致索引不能命中

    今天写了一个sql,其中涉及的表中的数据量都差不多为50w左右,查询发现用了8s.这个只是测试服上数据,放到正式服上,肯定一运行就挂了. SELECT Orders. NO, GuidNo, Orde ...

  5. SpringBoot学习(二)-->Spring的Java配置方式

    二.Spring的Java配置方式 Java配置是Spring4.x推荐的配置方式,可以完全替代xml配置. 1.@Configuration 和 @Bean Spring的Java配置方式是通过 @ ...

  6. Prism 学习:从配置文件中加载 Module

    之前我们已经了解过,如何从指定的目录中来加载 Module(原文),现在我们来看,如何从应用程序的配置文件中来加载 Module.以这种方式来加载 Module 的优点包括:1. 被加载的 Modul ...

  7. Windows驱动匹配详解

    在Windows下,几乎所有的硬件设备都需要安装驱动后才能正常工作,我们重装系统后第一件事就是要为各设备安装好驱动,我们可以下载官方驱动手动安装,也可以让我Windows自动扫描安装,还可以使用驱动精 ...

  8. JavaScript中的三种弹窗

    ---恢复内容开始--- 1.警告窗口(alert) <script type="text/javascript"> alert("我是警告弹框!" ...

  9. Docker 系列三(容器管理).

    一.运行容器 1.基于镜像新建一个容器并启动 : tomcat:8.0 -i:交互式操作 -t:终端 -rm:容器退出后随之将其删除,可以避免浪费空间 -p :端口映射 -d :容器在后台运行 指明了 ...

  10. 通过示例学习JavaScript闭包

    译者按: 在上一篇博客,我们通过实现一个计数器,了解了如何使用闭包(Closure),这篇博客将提供一些代码示例,帮助大家理解闭包. 原文: JavaScript Closures for Dummi ...