ObjectBox使用简记

这两天听朋友说起了最近Android出来了一个NoSql数据库ObjectBox,怀揣着好奇就建了一个Android程序进行了简单的运用和测试,感觉效果很好,特此记~

  • 此文主要供 Kotlin使用ObjectBox

1.添加依赖

  • 在project的build.gradle添加如下配置
buildscript {
   //目前版本是1.4.1
    ext.objectboxVersion = '1.4.1'
    ext.kotlin_version = '1.2.10'
    repositories {
        google()
        jcenter()
      maven { url "http://objectbox.net/beta-repo/" }
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.0.1'
        classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
        classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
        classpath "io.objectbox:objectbox-gradle-plugin:$objectboxVersion"
    }
}

allprojects {
    repositories {
        google()
        jcenter()
        maven { url "http://objectbox.net/beta-repo/" }
    }
}
  • 在app的build.gradle中需要添加如下配置
apply plugin: 'com.android.application'

apply plugin: 'kotlin-android'

apply plugin: 'kotlin-android-extensions'

apply plugin: 'kotlin-kapt'


//此依赖主要用于browser,可以在浏览器中查看app的数据
dependencies {
  debugImplementation "io.objectbox:objectbox-android-objectbrowser:$objectboxVersion"
  releaseImplementation "io.objectbox:objectbox-android:$objectboxVersion"
}

//一定要在 上面两个依赖之下 此plugin
apply plugin: 'io.objectbox' // after applying Android plugin


//在正常的dependencies中添加如下依赖
dependencies{
//主要是针对kotlin
compile "io.objectbox:objectbox-kotlin:$objectboxVersion"
}
  • 在应用中的正常使用(建议在Applicaion中初始化),以下是初始化(我也是初学kotlin可能存在一些语法不够简洁,不喜勿喷哈):
class App : Application() {
  override fun onCreate() {
    super.onCreate()
    initObjectBox()
  }

  //定义静态块 静态方法
  companion object {
    lateinit var boxStore: BoxStore
    fun getBoxStoreInstance() = boxStore
  }

  private fun initObjectBox() {
    boxStore = MyObjectBox.builder().androidContext(this).build()
    if (BuildConfig.DEBUG) {
      boxStore?.let {
        //可以理解为初始化连接浏览器(可以在浏览器中查看数据,下面再说)
        val started = AndroidObjectBrowser(boxStore).start(this)
        Log.i("ObjectBrowser", "Started: " + started)
      }
    }

  }
}
  • 创建实体类
//实体类学生
@Entity
class Student{
  @Id var id:Long = 0
  lateinit var name:String

  //这里是假设学生和老师的关系(relation)是一对一
  lateinit var teacher:ToOne
}

//实体类老师
@Entity
class Teacher{
  @Id var  id:Long =0

  lateinit var name:String

  //这里假设老师和学生的关系是一对多(一个老师有多个学生)
  @Backlink
  lateinit var students: ToMany
}
  • 基本使用方法
//此处是我在Application里面做了初始化操作
var boxStore = App.getBoxStoreInstance()

//如果没有在Application里面初始化,使用的地方初始化可以这样操作,MyObjectBox需要build工程之后才会出来
//var boxStore = MyObjectBox.builder().androidContext(this).build()
var studentBox: Box = boxStore.boxFor()
var teacherBox: Box = boxStore.boxFor()

//创建一个老师对象和一个学生对象
var teacher = Teacher()
teacher.name = "我是老师"
//学生和老师的relation是1对1 如果没有关系则不用这一步
//student.teacher.target = teacher

var student = Student()
student.name = "我是学生"


//创建一个学生列表
var allStudents: MutableList = mutableListOf()

//老师和学生是一对多的关系,不用relation则可以不用次关系
teacher.students.addAll(allStudents)

//以下是对数据的基本操作
//- 添加数据(可以单个数据添加,也可以添加一个列表数据)
studentBox.put(student)
studentBox.put(mutableListOf())

//查询数据的几种方式
1.get方式查询数据(可以传入id,id列表等等,具体查看api)
var student=studentBox.get(id)

2.find方式(传入你Entity对应的属性和值进行查询,Student_构建会自动生成)
var findStudents: List = studentBox.find(Student_.name, "张三")

3.query方式(适用于复杂查询可以拼接各种条件,如下简单拼接)
var queryStudents: List = studentBox.query()
        .equal(Student_.name, "张三")
        .between(Student_.id, 1, 10)
        .build()
        .find();

//更新数据的操作和插入的操作相同都是put
studentBox.put(student)

//删除数据的操作(可以单个id,多个id,单个对象,对象列表等)
studentBox.remove(id)
studentBox.remove(id1,id2...)
studentBox.remove(student)
studentBox.remove(mutableListOf())
  • 其他操作(browser查看数据),上面依赖其实已经添加过也加了注释,但是在这还是做个补充吧.
//1.app的build.gradle中加入如下依赖
dependencies {
    debugImplementation "io.objectbox:objectbox-android-objectbrowser:$objectboxVersion"
    releaseImplementation "io.objectbox:objectbox-android:$objectboxVersion"
}
//一定要在 上面两个依赖之下 此plugin
apply plugin: 'io.objectbox'



//2.代码中加入如下代码(加入到初始化之后)
if (BuildConfig.DEBUG) {
      boxStore?.let {
        val started = AndroidObjectBrowser(boxStore).start(this)
        Log.i("ObjectBrowser", "Started: " + started)
      }


//3.在manifest中添加网络访问权限


4.以上已经完成基本浏览数据的配置,如果Android手机当前引用的消息通知是打开的会打开的,
则会收到一条通知点击通知则浏览器会打开数据浏览。如果需要浏览器打开则需要转发端口

adb forward tcp:8090 tcp:8090

浏览器可以访问 http://localhost:8090/index.html 直接打开
  • 温馨提示
1.@Id var  id:Long =0 表示ID从1开始 自增长 且必须指定为Long类型

2.数据的存储位置为/data/data/com.xx.xx(应用包名)/objectbox/

如上即学习ObjectBox一点简记,如有错误欢迎指正~

你可能感兴趣的:(ObjectBox使用简记)