马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?立即注册
x
}
}
在你app的build.gradle中:
compile ‘com.facebook.stetho:stetho:1.5.0’
compile ‘com.uphyca:stetho_realm:2.1.0’
stetho_realm的github地点:https://github.com/uPhyca/stetho-realm
package tsou.com.simple.realmtest;
import android.app.Application;
import android.content.Context;
import com.facebook.stetho.Stetho;
import com.uphyca.stetho_realm.RealmInspectorModulesProvider;
import java.security.SecureRandom;
import io.realm.Realm;
import io.realm.RealmConfiguration;
import tsou.com.simple.realmtest.migration.CustomMigration;
import tsou.com.simple.realmtest.utils.UIUtils;
/**
- Created by Administrator on 2017/12/15 0015.
*/
public class MyApplication extends Application {
/**
*/
private static MyApplication instance;
private static RealmConfiguration config;
private static String key = “huangxiaoguo1234”;
@Override
public void onCreate() {
super.onCreate();
/**
*/
Stetho.initialize(
Stetho.newInitializerBuilder(this)
.enableDumpapp(Stetho.defaultDumperPluginsProvider(this))
.enableWebKitInspector(RealmInspectorModulesProvider.builder(this).build())
.build());
Realm.init(this);
instance = this;
new SecureRandom().nextBytes(UIUtils.getRealmKey(key));
config = new RealmConfiguration.Builder()
.name(“huangxiaoguo.realm”)//指定命据库的名称。如不指定默认名为default。
.schemaVersion(0)
.deleteRealmIfMigrationNeeded()//声明版本冲突时自动删除原数据库,开发时间打开
// .inMemory()// 声明数据库只在内存中长期化
.build();
}
public static Context getInstance() {
return instance;
}
public static RealmConfiguration getRealmConfiguration() {
return config;
}
}
RealmConfiguration支持的方法:
- Builder.name : 指定命据库的名称。如不指定默认名为default。
- Builder.schemaVersion : 指定命据库的版本号。
- Builder.encryptionKey : 指定命据库的密钥。
- Builder.migration : 指定迁移操作的迁移类。
- Builder.deleteRealmIfMigrationNeeded : 声明版本冲突时自动删除原数据库。
- Builder.inMemory : 声明数据库只在内存中长期化。
- build : 完成配置构建。
package tsou.com.simple.realmtest.utils;
import android.content.Context;
import android.content.res.AssetManager;
import android.widget.Toast;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import io.realm.Realm;
import tsou.com.simple.realmtest.MyApplication;
public class UIUtils {
private static Toast toast;
/**
- 静态吐司
- @param context
- @param text
*/
public static void showToast(Context context, String text) {
if (toast == null) {
toast = Toast.makeText(context, text, Toast.LENGTH_SHORT);
}
toast.setText(text);
toast.show();
}
/**
*/
public static void showToast(String text) {
showToast(getContext(), text);
}
/**
*/
public static Context getContext() {
return MyApplication.getInstance();
}
/**
*/
public static Realm getRealmInstance() {
return Realm.getInstance(MyApplication.getRealmConfiguration());
}
/**
- 获取Realm数据库64位秘钥
- @param key
- @return
*/
public static byte[] getRealmKey(String key) {
String newKey = “”;
for (int i = 0; i < 4; i++) {
newKey = newKey + key;
}
return newKey.getBytes();
}
/**
- 从asset路径下读取对应文件转String输出
- @return
*/
public static String getJson(String fileName) {
StringBuilder sb = new StringBuilder();
AssetManager am = getContext().getAssets();
BufferedReader br = null;
try {
br = new BufferedReader(new InputStreamReader(
am.open(fileName)));
String next = “”;
while (null != (next = br.readLine())) {
sb.append(next);
}
} catch (IOException e) {
e.printStackTrace();
sb.delete(0, sb.length());
} finally {
try {
if (br != null) {
br.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
return sb.toString().trim();
}
}
在UIUtils工具类中getRealmInstance方法就是得到Realm实例的,其他的方法后期会用到。
方式一:继承RealmObject
package tsou.com.simple.realmtest.bean;
import java.io.Serializable;
import io.realm.RealmObject;
import io.realm.annotations.Ignore;
import io.realm.annotations.PrimaryKey;
import io.realm.annotations.Required;
/**
- Created by Administrator on 2017/12/15 0015.
-
- 直接继承于RealmObject来声明 Realm 数据模子
-
- 注意:如果你创建Model并运行过,然后修改了Model。
- 那么就需要升级数据库,否则会抛非常。
*/
public class User extends RealmObject {
/**
- 表示该字段是主键
-
- 字段类型必须是字符串(String)或整数(byte,short,int或long)
- 以及它们的包装类型(Byte,Short, Integer, 或 Long)。不可以存在多个主键,
- 利用字符串字段作为主键意味着字段被索引(表明@PrimaryKey隐式地设置表明@Index)。
*/
@PrimaryKey
private int id;
/**
- 表示该字段非空
-
- 只能用于Boolean, Byte, Short, Integer, Long, Float, Double, String, byte[] 和 Date。
- 在别的类型属性上利用 @Required修饰会导致编译失败
-
- 注意:根本数据类型不需要利用注解 @Required,由于他们本身就不可为空。
*/
@Required
private String name;
private int age;
/**
- 表示忽略该字段
-
- 被添加@Ignore标签后,存储数据时会忽略该字段。
*/
@Ignore
private String sex;
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;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
}
支持的属性
boolean, byte, short,int,long,float, double,String,
Date 和,byte[], RealmObject,
RealmList< “?” extends RealmObject>
还支持Boolean, Byte, Short, Integer, Long, Float 和 Double
整数类型 short、int 和 long 都被映射到 Realm 内的雷同类型(现实上为 long )
方式二:实现 RealmModel接口并添加 @RealmClass修饰符来声明。
package tsou.com.simple.realmtest.bean;
import io.realm.RealmModel;
import io.realm.annotations.PrimaryKey;
import io.realm.annotations.RealmClass;
/**
- Created by Administrator on 2017/12/15 0015.
-
- 通过实现 RealmModel接口并添加 @RealmClass修饰符来声明
-
- 注意:如果你创建Model并运行过,然后修改了Model。
- 那么就需要升级数据库,否则会抛非常。
*/
@RealmClass
public class Student implements RealmModel {
private String name;
private int num;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getNum() {
return num;
}
public void setNum(int num) {
this.num = num;
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |