安卓日记——Realm快速上手

Realm作为一种新兴的数据库以其变态的速度吸引了我们,摆图看看它有多快
这里写图片描述
力压主流Sqlite,所以学习Realm就很有必要了

1.在项目的build.gradle=>buildscript=>dependencies添加

classpath "io.realm:realm-gradle-plugin:1.0.1"

添加后效果如下


buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.0.0'
        classpath "io.realm:realm-gradle-plugin:1.0.1"
    }
}

2.在moudle的build.gradule里头部添加

apply plugin: 'realm-android'

3.开始使用Realm

RealmConfiguration realmConfig = new RealmConfiguration.Builder(this).build();
        Realm.setDefaultConfiguration(realmConfig);
realm=Realm.getDefaultInstance();

最好把realm设为Realm类型的全局变量因为最后要把它关闭掉
我这里只介绍最简单的方法,至于配置表名,表的版本这里不详细介绍

4.声明开始事务

        realm.beginTransaction();
        //TODO
        realm.commitTransaction();

开始前要beginTransaction,结束后要commitTransaction
不过还有另外两种方式

第一种同步执行

realm.executeTransaction(new Realm.Transaction() {
                @Override
                public void execute(Realm realm) {
                    //TODO         
                }
            });

第二种异步执行

                realmAsyncTask=realm.executeTransactionAsync(new Realm.Transaction() {
                @Override
                public void execute(Realm realm) {
                //TODO
                }

            });

为什么要返回一个 RealmAsyncTask的值呢,因为如果你在跳转Activity之后想中止这个过程则要把realmAsyncTask 关掉,就像网络请求一样。

5.新建实体

public class Country extends RealmObject {
    private String name;
    private int population;

    public Country() { }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getPopulation() {
        return population;
    }

    public void setPopulation(int population) {
        this.population = population;
    }
}

实体必须是继承自RealmObject

6.增加

        realm.beginTransaction();
        Country country=realm.createObject(Country.class);
        country.setPopulation(1000000);
        country.setName("China");
        realm.commitTransaction();

7.查询

RealmResults<Country>realmResults =realm.where(Country.class).findAll();

支持以下几种条件查询

  • between()、greaterThan()、lessThan()、greaterThanOrEqualTo() 和
    lessThanOrEqualTo()
  • equalTo() 和 notEqualTo()
  • contains()、beginsWith() 和 endsWith()
  • isNull() 和 isNotNull()
  • isEmpty() 和 isNotEmpty()
  • or()和and()
  • not()

    若想结果排序,可将findall换成findAllSorted

        //结果对poppulation升序排序
        RealmResults<Country> results3 =
                realm.where(Country.class)
                        .findAllSorted("population", Sort.ASCENDING);

如果是降序则要把Sort.ASCENDING换成Sort.DESCENDING**

8.删除

无论是删除和修改都是基于查询语句的

        realm.beginTransaction();
        //删除查询到的所有项
        results3.deleteAllFromRealm();
        //删除查询到的location为2的项
        results3.deleteFromRealm(2);
        //删除查询到的第一项
        results3.deleteFirstFromRealm();
        //删除查询到的最后一项
        results3.deleteLastFromRealm();
        realm.commitTransaction();

9.修改

        realm.beginTransaction();
        //将loacation为0的项的population改为13000000
        Country mCountry=results3.get(0);
        mCountry.setPopulation(13000000);
        realm.commitTransaction();

总结

Realm虽然速度快,但他的扩展性不及其实sqlite的库,导致有些人不喜欢用,这世界上并没有完美的东西,至于你们怎么选择就看你们自己的取舍吧

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值