探究ObjectBox

ObjectBox是移动端数据库框架,灵感来自于NoSql,速度非常快,号称是市面上最快的移动端数据库框架。目前非关系行数据库也就只有Realm 能与之相比。本文将会探讨两个框架的取舍。

一、为什么要使用ObjectBox?

官方给出来的有五大特性:

1、快: 比测试过的其它数据库快 5~15 倍

2、面向对象的 API: 没有 rows、columns 和 SQL,完全面向对象的 API

3、即时的单元测试: 因为它是跨平台的,所以可以在桌面运行单元测试

4、简单的线程: 它返回的对象可以在任何线程运转

5、不需要手动升级和迁移: 升级是完全自动的,不需要关心属性的变化以及命名的变化


二、如何安装?

1、首先在根目录的gradle 文件中添加:

buildscript {

          repositories {

          jcenter()

          maven { url "http://objectbox.net/beta-repo/" }

  }

dependencies {

         classpath 'com.android.tools.build:gradle:2.3.2'

         classpath 'io.objectbox:objectbox-gradle-plugin:0.9.12.1'

   }

}

2.在你的项目gradle 文件中添加:

apply plugin: 'com.android.application'

apply plugin: 'io.objectbox'

repositories {

        jcenter()

        maven { url "http://objectbox.net/beta-repo/" }

}

dependencies {

       compile 'io.objectbox:objectbox-android:0.9.12'

}

ps.此时gradle 的时候有可能图1出现的问题:

图1


这问题是因为,AS2.3.3版本会默认把Expresso框架自动引入,谷歌默认的现在是3.0.5版本,而Objectbox中使用的是3.0.2版本,有个版本冲突,所以统一一下版本即可,在gradle dependency中添加即可:

androidTestCompile'com.google.code.findbugs:jsr305:3.0.2'


三、如何使用?

1.初始化

在 Application 中初始化boxStore = MyObjectBox.builder().androidContext(App.this).build();

2.对象注解

ObjectBox跟其他的ORM框架一样,通过对象属性注解来决定是否要持久化某个对象,或者某个属性。接下来看看常见的注解。


探究ObjectBox_第1张图片
图2

如图2所示,这是一个Categoty 对象,

@Entity:这个对象需要持久化。

@Id:这个对象的主键。

@Index:这个对象中的索引。对经常大量进行查询的字段创建索引,会提高你的查询性能。

@NameInDb:有的时候数据库中的字段跟你的对象字段不匹配的时候,可以使用此注解。

@Transient:如果你有某个字段不想被持久化,可以使用此注解。

@Relation:做一对多,多对一的注解。

需要注意的是:默认情况下,id是会被objectbox管理的,也就是自增id,如果你想手动管理id需要在注解的时候加上@Id(assignable = true)即可。当你在自己管理id的时候如果超过long的最大值,objectbox 会报错。id=0的表示此对象未被持久化,id的值不能为负数。

3.增删查改

(1)新增

调用box put 方法即可完成新增。

探究ObjectBox_第2张图片
图3

(2) 删除   

调用box remove 方法即可完成删除。

roleBox.remove(2);//删除id=2的对象

roleBox.removeAll();//清空所有表对象

(3)查询

首先要获取 Box 对象,然后通过 QueryBuilder 查询,以下是一个找出角色名称以采字开头的角色以及或者角色等于“运营”人员的例子:

List item =roleBox.query().startsWith(Role_.role_name,"采")

.or().equal(Role_.role_name,"运营")

.orderDesc(Role_.created_at).build().find();

QueryBuilder 还提供了形如greater、less、contain等 API,使用非常方便。

(4)修改

调用put 方法,即可完成更新动作。

4、事务

框架提供了四个事务机制:

runInTx:在给定的runnable 中运行的事务。

runInReadTx:只读事务,不同于runintx,允许并发读取。

runInTxAsync:运行在一个单独的线程中执行,执行完成后,返回callback。

callInTx:与runInTx 相似,不同的是可以有返回值。

看这个例子:

新增30000个role 对象:

探究ObjectBox_第3张图片
图4

此例子会有什么问题?

5、数据库升级

在新增和删除字段的时候,基于NoSql的特性ObjectBox会自动的升级你的数据库。不像Sqlite数据库需要准备版本号,准备数据库的sql升级脚本,这点来看是十分方便的。如果你有在原来的基础上修改字段的需求,可以这样做:

1、在你要修改的表添加@Uid注解。

探究ObjectBox_第4张图片
图5

2、编译项目,make project

探究ObjectBox_第5张图片
图6

3、直接修改你要的字段

探究ObjectBox_第6张图片
图7

6、与RxJava实现的数据监听

ObjectBox提供了RxJava的扩展,实现了数据库操作的全程异步,以及数据异步监听机制。对UI性能毫无影响。接下来看个简单的例子:

监听Role表的数据,如果有新增,则更新UI列表数据。

图8

值得注意的一点:在页面关闭的时候记得:subscription.cancel() 记得取消监听动作。

四、与Realm 性能比较

1、新增性能

同时插入10000、50000、100000条数据的时间对比:

探究ObjectBox_第7张图片

可以看出,ObjectBox速度是Realm的3-4倍左右。


2.删除性能

同时删除10000、50000、100000条数据的时间对比:

可以看出ObjectBox速度是Realm的2倍左右。

探究ObjectBox_第8张图片

3.更新新能

同时更新10000、50000、100000条数据时间对比:

探究ObjectBox_第9张图片

可以看出ObjectBox速度是Realm的2倍左右。

五、总结

ObjectBox相对而言操作十分简单、易用。重点是还超快。我们没有理由不用他,相对Realm而言,目前ObjectBox只支持Java和android,官方已经宣布会支持ios 和mac系统。

你可能感兴趣的:(探究ObjectBox)