本文共 8226 字,大约阅读时间需要 27 分钟。
好长时间没有写关于Android方面的学习文章了,今天给大家带来的是堪称是一个可以替代SQLite以及ORMlibraries的轻量级数据库—Realm移动端数据库。
相比SQLite,Realm更快并且具有很多现代数据库的特性,比如支持JSON,流式api,数据变更通知,以及加密支持,这些都为安卓开发者带来了方便。
Ream提供了五种编程方式的实现。分别是Java,Objective C,Swift,React-Native,tamarin。在这里我着重介绍在Android中的使用。后面也会介绍在Swift中得使用。
Realm资源包中包含了一个很有用的实用工具,可以帮助我们更好地管理Realm数据库,那就是Realm Browser。Realm Browser可以让您轻松地读写Realm数据库(以.realm结尾),因此我们无需头疼如何去查看Realm专有数据库的逻辑结构以及其中的数据,可视化的操作就如同SQLite的其他数据库查看工具一样,十分简单、易用(虽然Realm Browser的功能还十分简陋,真的只能读写而已)。
在本案例中我使用的最新版本的1.0.0版本。
apply plugin: 'realm-android'buildscript { repositories { jcenter() maven { url 'https://jitpack.io' } } dependencies { classpath "io.realm:realm-gradle-plugin:1.0.0" }}
package com.lidong.demo.realm;import android.content.Context;import io.realm.Realm;import io.realm.RealmConfiguration;/****@className:RealmUtil*@desc:RealmUtil工具类*@author:lidong*@datetime:16/6/10 下午9:55*/public class RealmUtil { private static RealmUtil sIntance; public final Context mContext; private String realmName = "realm_demo.realm"; public RealmUtil(Context mContext) { this.mContext = mContext; } /** * 双检索单例 * @param context * @return */ public static RealmUtil getIntance(Context context){ if (sIntance == null) { synchronized (RealmUtil.class) { if (sIntance == null) { sIntance = new RealmUtil(context); } } } return sIntance; } /** * 获取realm对象 * @return */ public Realm getRealm(){Realm realm =Realm.getInstancenew RealmConfiguration.Builder(mContext) .name(realmName) .build()); return realm; }}
只要继承了RealmObject类,任意JavaBean都能存储在Realm中。必须有一个默认构造器,成员变量有相应的getter/setter方法
package com.lidong.demo.realm;import io.realm.RealmObject;import io.realm.annotations.PrimaryKey;/** * Person */public class Person extends RealmObject { @PrimaryKey private String code;//编号 private String name;//姓名 private int age;//年龄 public Person() { } public Person(int age, String code, String name) { this.age = age; this.code = code; this.name = name; } public String getCode() { return code; } public void setCode(String code) { this.code = code; } 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; } @Override public String toString() { return "Person{" + "code='" + code + '\'' + ", name='" + name + '\'' + ", age=" + age + '}'; }}
PersonDao.java
package com.lidong.demo.realm;import java.util.List;/** * Created by lidong on 16/6/9. */public interface PersonDao { /** * 插入Person * @param person * @throws Exception */ void insert(Person person)throws Exception; /** * 获取所有的用户 * @return * @throws Exception */ ListgetAllPerson()throws Exception; /** * 更新用户 * @throws Exception */ Person updatePerson(Person person)throws Exception; /** * 删除用户 * @param code * @throws Exception */ void deletePerson(String code)throws Exception; /** * 异步插入Person * @param person * @throws Exception */ void insertPersonAsync(Person person)throws Exception;}
PersonDaoImp.java
package com.lidong.demo.realm;import android.content.Context;import java.util.List;import io.realm.Realm;/****@className:PersonDaoImpl*@desc:*@author:lidong*@datetime:16/6/10 下午10:01*/public class PersonDaoImpl implements PersonDao { private Context context; private Realm mRealm; public PersonDaoImpl(Context context){ mRealm = RealmUtil.getIntance(context).getRealm(); } /** * @同步插入用户 * @param person * @throws Exception */ @Override public void insert(Person person) throws Exception { mRealm.beginTransaction(); Person person1 = mRealm.copyToRealm(person); mRealm.commitTransaction(); mRealm.close(); } /** * 获取所有的用户 * * @return * @throws Exception */ @Override public ListgetAllPerson() throws Exception { List mlist = null; mlist = mRealm.where(Person.class).findAll(); mRealm.close(); return mlist; } /** * @param person * @throws Exception */ @Override public Person updatePerson(Person person) throws Exception { mRealm.beginTransaction(); Person person1 = mRealm.copyToRealmOrUpdate(person); mRealm.commitTransaction(); mRealm.close(); return person1; } @Override public void deletePerson(String code) throws Exception { Person person = mRealm.where(Person.class).equalTo("code",code).findFirst(); mRealm.beginTransaction(); person.deleteFromRealm(); mRealm.commitTransaction(); } /** * 异步插入Person * * @param person * @throws Exception */ @Override public void insertPersonAsync(final Person person) throws Exception { //一个Realm只能在同一个线程中访问,在子线程中进行数据库操作必须重新获取Realm对象: mRealm.executeTransaction(new Realm.Transaction() { @Override public void execute(Realm realm) { realm.beginTransaction(); Person person1 = realm.copyToRealm(person); realm.commitTransaction(); realm.close();//并且要记得在离开线程时要关闭 realm.close(); } }); mRealm.close();//关闭Realm对象 }}
package com.lidong.demo.realm;import android.os.Bundle;import android.support.v7.app.AppCompatActivity;import android.util.Log;import com.lidong.demo.R;import java.util.List;import io.realm.Realm;public class DemoRealmActivity extends AppCompatActivity { static final String TAG = DemoRealmActivity.class.getSimpleName(); Realm mRealm; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_demo_realm);// mRealm= RealmUtil.getIntance(this).getRealm();////// mRealm.executeTransaction(new Realm.Transaction() { // @Override// public void execute(Realm realm) { // Person person = realm.createObject(Person.class);// person.setName("李东");// person.setAge(24);// person.setCode(UUID.randomUUID().toString());// }// }); Person person = new Person(); person.setName("李东1"); person.setAge(28); person.setCode("6e56d3aa-7119-429e-8c59-7ad8241e838d"); PersonDao dao = new PersonDaoImpl(this);// try { // dao.insert(person);// } catch (Exception e) { // e.printStackTrace();// } try { dao.deletePerson("6e56d3aa-7119-429e-8c59-7ad8241e838d"); } catch (Exception e) { e.printStackTrace(); } try { Listpersons = dao.getAllPerson(); Log.d(TAG, "onCreate: "+persons); } catch (Exception e) { e.printStackTrace(); } } @Override protected void onDestroy() { super.onDestroy(); }}
总结:Android中使用Realm数据库基本上就这几点步骤,这是个入门,更加复杂的操作,我在后面会慢慢的深入。