Realm 基本用法

前提

Android Studio 1.5.1 或者更高版本;
JDK 版本 >=7;
较新的 Android SDK 版本;
支持 Android API 9 以上的所有版本(Android 2.3 Gingerbread 及以上)。

为什么使用Realm

Realm Java 让你能够高效地编写 app 的模型层代码,保证你的数据被安全、快速地存储。

1、Realm基本配置

A.在module的build.gradle中添加如下代码:

apply plugin: 'realm-android'

如图所示:

1.png

B.在project的build.gradle中添加如下代码:

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

如图所示:

1.png

现在基本配置已经弄好了,可以开始操作一波了。

2、数据库基本操作(增删改查)

在做这些操作之前我们需要新建model类(类似sqlite的新建表),这里我们需要继承RealmObject才能被存储在数据库中。

public class Person extends RealmObject{
    private int id;
    private String name;
    private int age;

    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
       this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
}

表已经建好了,这时候可以对它CRUD(create/read/update/delete)了。
a.新增数据
这里需要说一下,新增数据操作需要在事务进行。如下所示:

        Realm mRealm = Realm.getDefaultInstance();//获取Realm实例              
        mRealm.executeTransaction(new Realm.Transaction() {
            @Override
            public void execute(Realm realm) {
                //Add a person
                Person person = realm.createObject(Person.class);
                person.setId(1);
                person.setName("Young Person");
                person.setAge(14);
            }
        });

或者

 Realm mRealm = Realm.getDefaultInstance();//获取Realm实例   
 mRealm.beginTransaction();
 //Add a person
 Person person = realm.createObject(Person.class);
 person.setId(1);
 person.setName("Young Person");
 person.setAge(14);
 mRealm.commitTransaction();

b.查询数据

Realm mRealm = Realm.getDefaultInstance();//获取Realm实例   
final Person person = mRealm.where(Person.class).findFirst();//查询第一条数据

相关查询API如下所示:
1️⃣ average(String fieldName) ->返回给定字段的平均值
2️⃣ beginGroup ->开始条件分组(“左括号”)
3️⃣ beginsWith(String fieldName,String value) ->查询以“value”开头的“fieldName”
4️⃣ between(String fieldName,float from,float to) ->查询fieldName字段在"from"和to之间

好了,方法挺多的,这里就举几个例子,顺便给出Realm API网址(https://realm.io/docs/java/3.5.0/api/)有兴趣的可以去看一下。

c.更新数据

Realm mRealm = Realm.getDefaultInstance();//获取Realm实例   
final Person person = mRealm.where(Person.class).findFirst();//查询第一条数据
//更新第一条数据
 mRealm.executeTransaction(new Realm.Transaction() {
            @Override
            public void execute(Realm realm) {
                person.setName("Senior Person");
                person.setAge(88);
            }
        });

d.删除数据

Realm mRealm = Realm.getDefaultInstance();//获取Realm实例   
mRealm.executeTransaction(new Realm.Transaction() {
   @Override
    public void execute(Realm realm) {
        //清空Person表
        realm.delete(Person.class);
    }
 });

3、数据库迁移(数据库升级)

所有数据库都要处理模型改变的情况。Realm 的数据模型用标准 Java 对象来定义,改变数据模型只需要改变数据对象定义即可。
Application中需要如下自定义配置:

  // Initialize Realm. Should only be done once when the application starts.
  Realm.init(this);
  RealmConfiguration myConfig=new RealmConfiguration.Builder()
                .schemaVersion(REALM_VERSION)
                .migration(new MyConfigMigration())
                .name("myrealm.realm")
                .build();
  Realm.setDefaultConfiguration(myConfig);

这时候我们需要自定义Migration

public class MyConfigMigration implements RealmMigration {
    public static final String TAG = "ez";

    @Override
    public void migrate(DynamicRealm realm, long oldVersion, long newVersion) {

        realmUpdate((int) oldVersion,realm);

        //官方写法
//        if (oldVersion == 0 && newVersion == 1) {
//            version1(realm);
//            ++oldVersion;
//        }
//
//        if (oldVersion == 1 && newVersion == 2) {
//            version2(realm);
//            ++oldVersion;
//        }

    }

    /**
     * realm数据库迁移(升级)
     * 降级:需要使用if判断来处理
     * @param oldVersion
     * @param realm
     */
    private void realmUpdate(int oldVersion, DynamicRealm realm) {
        switch (oldVersion) {
            case 0:
                version1(realm);
            case 1:
                version2(realm);
            default:
                break;
        }
    }

    /**
     * version=1时,增加fullName,删除name。
     * <p>
     * 注意:添加字段时,对应的model也要对应添加(如果标记的不为空,那么model也必须注解不为空),删除字段时,对应的model也要删除,
     *
     * @param realm
     */
    private void version1(DynamicRealm realm) {
        RealmSchema schema = realm.getSchema();
        RealmObjectSchema personSchema = schema.get("Person");
        personSchema.addField("fullName", String.class, FieldAttribute.REQUIRED)
                .transform(new RealmObjectSchema.Function() {

                    @Override
                    public void apply(DynamicRealmObject obj) {
                        obj.set("fullName", obj.get("name") + "Full");
                    }
                })
                .removeField("name");
    }

    /**
     * version=2时,增加了Pet类。
     */
    private void version2(final DynamicRealm realm) {
        RealmSchema schema = realm.getSchema();
        //创建对应表和表字段
        RealmObjectSchema petSchema = schema.create("Pet")
                .addField("name", String.class, FieldAttribute.REQUIRED)
                .addField("type", String.class, FieldAttribute.REQUIRED);
        //将创建的表添加到Person表中
        schema.get("Person")
                .addRealmListField("pets", petSchema)
                .transform(new RealmObjectSchema.Function() {
                    @Override
                    public void apply(DynamicRealmObject obj) {
                        if (obj.getString("fullName").equals("Senior PersonFull")) {
                            DynamicRealmObject pet = realm.createObject("Pet");
                            pet.setString("name", "Jemos");
                            pet.setString("type", "cat");
                            obj.getList("pets").add(pet);
                        }
                    }
                });
    }
}

当我们每次增加schemaVersion的值时,数据库就会走升级操作。
好了,上面就是Realm的基本用法。详细用法请参考官网:
a、中文版(版本3.1.1)https://realm.io/cn/docs/java/latest/#migrations
b、英文版(版本3.5.0)https://realm.io/docs/java/latest/
c、官方Realm使用Demo https://github.com/realm/realm-java

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,324评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,356评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,328评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,147评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,160评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,115评论 1 296
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,025评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,867评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,307评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,528评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,688评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,409评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,001评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,657评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,811评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,685评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,573评论 2 353

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,070评论 25 707
  • Realm是由Y Combinator公司孵化出来的一款可以用于iOS(同样适用于Swift&Objective-...
    小歪子go阅读 2,227评论 6 9
  • 煩躁…誰知道這傢伙坐我旁邊陷入自己播放的音樂中無法自拔是鬧哪樣!首先,不喜歡他播放的品種,欣賞不了,愛來愛去的...
    宋小朝阅读 207评论 0 1
  • 一 东 云对雨,雪对风,晚照对晴空。来鸿对去燕,宿鸟对鸣虫。三尺剑,六钧弓,岭北对江东。人间清暑殿,天上广寒宫。两...
    淡然雨阅读 243评论 3 1