Realm是一个开源的面向对象移动数据库。上个月,Realm的Android版本发布了,比iOS版本晚了三个月。

我们之前已经报道过,Realm没有使用SQLite作为它的引擎,而是用C++写了自己的引擎,他们的目标是提供一个聚焦移动领域的SQLite的替代者。现在它的Android版本已经发布了。

当前Android上的Realm的API和iOS版本有点不同,这也反映了Objective C和Java的差别。Java版本的API有更高的强类型(strong-typed)要求,也更连贯(fluent)。

比如,在iOS上,查询是通过静态方法如"objectWhere"来进行的,这将返回一个RLMArray。这里的谓词都是基于字符串的。以下就是基于Object C的查询方法:

RLMArray *tanDogs = [Dog objectsWhere:@"color = 'tan' AND name BEGINSWITH 'B'"];

另一方面,在Android下进行相同的查询却是这样的:

RealmResults<Dog> tanDogs = realm.where(Dog.class)                                  .equalTo("color", "tan")                                  .beginsWith("name", "B")                                  .findAll();

当然,这有可能会被一种跨iOS、Android和其他平台的文本查询语言所替代。Tim Anglade是Realm的产品主管,他在一封邮件中指出,未来API的发展方向很大程度取决于社区的反馈。

虽然Realm是一个面向对象的数据库,但它和其他同类产品还是有一些明显的不同。Tim解释道,当它用原生对象格式(native object format)来存储数据时,这些对象不会带着其语言特有的格式原封不动地存在磁盘上,而是通过C++引擎存储在一个全局的表中。这使得Realm可以通过各种语言来访问数据,还包括各种即时查询(adhoc query)。

相比关系数据库,这种混合了对象和表的方式的优势在于它使图查询(graph query)更高效——甚至在相对老旧的智能手机上,查询深度嵌套的对象图也不会影响系统反应速度。Realm发布的基准测试(benchmark)结果称,在普通操作上,Realm的速度最快要达到原始的SQLite的10倍。

如果你现在有一个应用程序使用CoreData(iOS上)或SQLite(Android上),并且想迁移到Realm,肯定有一些事要做。这不是随便拿来就能用的——Tim解释说,CoreData和SQLite倾向于使用一种非常标准化的形式,这种做法在Realm上行不通。你最好从对象的角度重新思考你的模式(schema)和模型(model)。

一旦你修改了你的模式,使之适用于Realm,接下来把现有数据从CoreData/SQLite迁移过来就简单了。只要配置一次迁移操作(从Realm数据库版本0到版本1),在迁移过程中,把你的SQLite数据加载到Realm对象中并保存它们。

或者,如果你的数据保存在远程服务器上,你可以从头新建Realm数据库。

在采用Realm之前,必须要考虑到它是一个最前沿的软件,这意味着将来它的API有可能做出和以前不兼容的修改。

你可以通过Android版本的Realm来了解更多,或者查看Github上的代码。

参考英文原文:Realm Brings SQLite Alternative to Android

更多相关文章

  1. Android获取系统的硬件信息、系统版本以及如何检测ROM类型
  2. 快速开发框架Afinal的使用(数据库操作,HTTP请求,网络图片加载,控件绑
  3. Android开发小记--开发实用工具类--数据库操作类
  4. android 使用socket与pc传递对象的问题
  5. php实现post请求 接收android客户端json数据 存储数据库 并返回j
  6. android 兼容各个版本 读取通讯录
  7. Android之数据存储详解(二)之SQLite数据库存储数据
  8. Android(1.1-4.2) platform 开发包【全版本】
  9. Android探索之旅 | 面向对象和Java基础

随机推荐

  1. 一键安装mysql5.7及密码策略修改方法
  2. Windows下MySQL安装教程图文详解
  3. MYSQL实现排名及查询指定用户排名功能(并
  4. mysql如何利用binlog进行数据恢复详解
  5. MySQL8.0安装中遇到的3个小错误总结
  6. Mysql常用基准测试命令总结
  7. 关于Mysql通用查询日志和慢查询日志分析
  8. 你的like语句为什么没索引详解
  9. MySQL高效导入多个.sql文件方法详解
  10. MySQL中的排序函数field()实例详解