ObjectBox在Android Studio中的使用

提要

ObjectBox版本: v2.3.1( 2019/01/08)
Android Studio版本: 3.3

  • ObjectBox由greenrobot开发,其他产品有GreenDao、EventBus。ObjectBox是基于noSql的ORM数据库, 支持表关系的定义以及事务的处理, 在性能上官网称优于对比测试的所有嵌入型数据库5-15倍。

1.集成方法

// Top-level build file where you can add configuration options common to all sub-projects/modules.

buildscript {
    ext.objectboxVersion = '2.3.1'
    repositories {
        google()
        jcenter()
        maven { url "http://objectbox.net/beta-repo/" }
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.3.0'
        //ObjectBox
        classpath "io.objectbox:objectbox-gradle-plugin:$objectboxVersion"
        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        google()
        jcenter()
        maven { url "http://objectbox.net/beta-repo/" }
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

  • ②在app Model里的build.gradle文件里添加插件
apply plugin: 'com.android.application'
apply plugin: 'io.objectbox'
......
......
dependencies {
    //ObjectBox
    annotationProcessor "io.objectbox:objectbox-processor:$objectboxVersion"
    //正式版
    implementation "io.objectbox:objectbox-android:$objectboxVersion"
}

此时需要先立刻同步一下项目,点击Sync Now下载依赖文件

使用方法

    1. 添加一个Bean类,使用@Entity注解, 进行表映射
/**
 * id必须使用使用注解 @Id,表示自增长
 * 如需手动管理应该用 @Id(assignable = true)
 * 不需要写get、set方法,否则会报错
 * 变量用public修饰符,总之我用private 时Build会报错
 */
@Entity
public class UserEntity  {
   @Id
   public long id;
   public String name;
   public String age;
}
    1. 完成以上步骤后,请点击Build→Make Project,这样MyObjectBox就自动生成了。
    1. 把ObjectBox对象单例并实例化, 一般放在application的onCreate()中
public class MyApplication extends Application{
    private static BoxStore mBoxStore;
@Override
    public void onCreate() {
        mBoxStore = MyObjectBox.builder().androidContext(this).build();
        if (BuildConfig.DEBUG) {
            new AndroidObjectBrowser(mBoxStore).start(this);
        }
        XLog.e("App===", "Using ObjectBox :" + BoxStore.getVersion() + " (" + BoxStore.getVersionNative() + ")");

    }
    public BoxStore getBoxStore() {
        return mBoxStore;
    }
}
  • 4.此时可以通过Box对象来针对这张表做增删改查了(put, get, remove, query)。
Box beanBox=  ((MyApplication) getApplication()).boxFor(UserEntity.class).build();

//新增和修改,put 的参数可以是 list
beanBox.put(bean);
//删除 id 为 2 的数据
beanBox.remove(2);
//查询,名字为 T 开头或者 age为 10 的数据
List item = beanBox.query()
        .startsWith(UserEntity_.name,"T")
        .or().equal(UserEntity_.age,"10").build().find();
//查询时,用到了生成类 UserEntity_通常是实体类加一个下划线。使用 builder.equal() 进行设置匹配,调用 startWith() 设置查询条件,find() 可以用于分页。

数据库升级

  • 首先,在要修改的字段添加 @Uid 注解。
  • 然后 Build -> Make Project,
  • 此时就可以直接修改字段的名称

官方有这样一个提示,假如需要插入或修改多条数据,可以这样做:

 for(User user: allUsers) {
    modify(user); // modifies properties of given user
    box.put(user);
 }
 //但这种做法可能会需要较多的时间、花费更多的性能,正确做法
 for(User user: allUsers) {
    modify(user); // modifies properties of given user
 }
 box.put(allUsers);

调试

apply plugin: 'com.android.application'
//apply plugin: 'io.objectbox' //注释此行
dependencies {
 //ObjectBox
    annotationProcessor "io.objectbox:objectbox-processor:$objectboxVersion"
    //调试 api
    debugImplementation "io.objectbox:objectbox-android-objectbrowser:$objectboxVersion"
    releaseImplementation "io.objectbox:objectbox-android:$objectboxVersion"
}
  • 清单文件申请权限

  • 重新Build运行后, 就可以从设备的通知栏点击进入查看数据库, 通过在cmd中输入adb forward tcp:8090 tcp:8090, 打开浏览器, 输入http://localhost:8090/index.html 网址即可查看数据库信息

你可能感兴趣的:(ObjectBox在Android Studio中的使用)