美文网首页
ObjectBox使用简记

ObjectBox使用简记

作者: 奋斗的小土豆 | 来源:发表于2018-02-01 16:48 被阅读0次

    这两天听朋友说起了最近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<Teacher>
    }
    
    //实体类老师
    @Entity
    class Teacher{
      @Id var  id:Long =0
    
      lateinit var name:String
    
      //这里假设老师和学生的关系是一对多(一个老师有多个学生)
      @Backlink
      lateinit var students: ToMany<Student>
    }
    
    • 基本使用方法
    //此处是我在Application里面做了初始化操作
    var boxStore = App.getBoxStoreInstance()
    
    //如果没有在Application里面初始化,使用的地方初始化可以这样操作,MyObjectBox需要build工程之后才会出来
    //var boxStore = MyObjectBox.builder().androidContext(this).build()
    var studentBox: Box<Student> = boxStore.boxFor<Student>()
    var teacherBox: Box<Teacher> = boxStore.boxFor<Teacher>()
    
    //创建一个老师对象和一个学生对象
    var teacher = Teacher()
    teacher.name = "我是老师"
    //学生和老师的relation是1对1 如果没有关系则不用这一步
    //student.teacher.target = teacher
    
    var student = Student()
    student.name = "我是学生"
    
    
    //创建一个学生列表
    var allStudents: MutableList<Student> = 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<Student> = studentBox.find(Student_.name, "张三")
    
    3.query方式(适用于复杂查询可以拼接各种条件,如下简单拼接)
    var queryStudents: List<Student> = 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中添加网络访问权限
    <uses-permission android:name="android.permission.INTERNET" />
    
    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使用简记

          本文链接:https://www.haomeiwen.com/subject/egxdzxtx.html