您的位置:首页 > 移动开发 > Android开发

Android数据库Realm学习(一)基本使用

2016-08-04 16:51 495 查看


Android数据库Realm学习(一)基本使用

Realm Java文档
技术文档,开卷有益

刚刚开始用Realm,肯定是要对比着SQLite来琢磨的,说几个个人认识:

一、SQLite中的数据库名对应Realm的啥

Realm可以简单直接使用,这个时候似乎是弱化了数据库名的存在,也就是这个时候的数据库文件是默认的default.realm。弱化不代表不用,在实现RealmConfiguration时,通过如下代码new RealmConfiguration.Builder(context).name("myrealm.realm")来控制和指定名字。

二、表名去了哪里?

这个开始也会有点纠结,就是转不过来这个思维。

继承RealmObject的类也可以理解为一张张表的类。这个应该是在实体类和数据库的表结构之间做了个平衡,一个很惊喜的平衡。虽然也带了一个问题:加到getter和setter的任何自定义逻辑实际上并不会被执行。

三、有没有再次封装的必要性?

这个不确定,应该有,但是像查询来说,realm的实现已经够简单了,封装感觉鸡肋点。

接下来开始使用了

1.在module的gradle中添加compile 'io.realm:realm-android:0.87.5';

2.随便搞个什么类,但是要继承RealmObject。

例如我声明个Book.class,包括name和author两条私有属性,原因如下:



3.然后再activity里面使用realm:

本来可以这样的

[java] view
plain copy







realm = Realm.getInstance(this);

但是,为了后续学习也为了不装X,先配置个RealmConfiguration好了。

[java] view
plain copy







<RealmConfiguration configuration = new RealmConfiguration.Builder(this)

.name("test.realm")//配置名字

.encryptionKey(new byte[64])//加密用字段,不是64位会报错

.schemaVersion(2)//版本号

// .setModules(xxxx)//不懂

// .migration(xxxx)//不懂

// .inMemory()//设置后会放在缓存中

.build();

realm = Realm.getInstance(configuration);

注意:不同的activity使用同一个.realm文件时配置必须相同;

所有操作都必须在事务内执行;

具体操纵:

①增

[java] view
plain copy







//添加一条数据到数据库

private void realmInsert(Realm realm) {

realm.beginTransaction();//必须先开启事务

Book book = realm.createObject(Book.class);

book.setAuthor("司马迁");

book.setName("史记");

realm.commitTransaction();//提交事务

book = realm.where(Book.class).findFirst();

}

②查

[java] view
plain copy







//查询一个数据库中第一个book

Book book = realm.where(Book.class)

.equalTo("name","史记")//相当于where name='史记'

.or()//或,连接查询条件;没有这个方法时,默认是隐式地被逻辑和(&)组合

.equalTo("author","司马迁")//相当于 author='司马迁'

.findFirst();

//整体相当于select * from (test.realm) where name='史记' or author='司马迁' limit 1;

//Book book = realm.where(Book.class).findFirst();



Realm的查询也是支持排序的,但是它的处理是在查询出结果后再进行排序。

[java] view
plain copy







RealmResults<Book> result = realm.where(Book.class).findAll();

//Result.sort(“name”);

Result.sort(“name”,Sort.DESCENDING);</span>

注意:目前并不是支持所有字符集



③改

修改之前要确定一件事,你的model中有@PrimaryKey约束的主键,

否则



[java] view
plain copy







private void realmUpdate(Realm realm){

realm.beginTransaction();//开启事务

Book b = new Book();//新建实例

b.setId(1);//book类新加的int属性,用@PrimaryKey注解作为主键

b.setAuthor("simaqian");

b.setName("史记");

realm.copyToRealmOrUpdate(b);//修改操作

realm.commitTransaction();//提交事务

}

修改还有一种方式,好像还是realm提倡和鼓励的方式,就是直接对查询到的结果修改,然后该修改就会反馈回数据库,例如:

[java] view
plain copy







private void realmUpdate(Realm realm){

realm.beginTransaction();

// Book b = new Book();

// b.setId(1);

// b.setAuthor("simaqian");

// b.setName("史记");

// realm.copyToRealmOrUpdate(b);

realm.where(Book.class).findFirst().setAuthor("斯巴达");

realm.commitTransaction();

realmSelect(realm);

}

感觉还是查询出来复制一份使用比较好。。。

④删

删除和修改一样,你的model中有@PrimaryKey约束的主键

[java] view
plain copy







private void realmDelete(Realm realm){

realm.beginTransaction();

RealmResults results = realm.where(Book.class).findAll();

//方式一:按下标删除

results.remove(1);

////方式二:删除指定model第一种

//Book book = new Book();

//book.setId(2);

//book.setName("史记");

//book.setAuthor("司牛迁");

//results.remove(book);

//方式三:删除指定model第一种

//book.removeFromRealm();

////方式四:删除末尾一个

//results.removeLast();

////方式wu:清除全部

//results.clear();

realm.commitTransaction();

}

转载自:http://blog.csdn.net/shareye1992/article/details/50789216

更多学习参考Realm官网
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: