IT技术

Android GreenDao 3.3.0 入门

2020-05-25  本文已影响0人  薰舞空

关联表:https://www.jianshu.com/p/6e3f0592f028
数据库升级:https://www.jianshu.com/p/b5267f732ee5

以前用的ormlite,后来换了GreenDao,更换主要原因是性能优势,GreenDao真不是一般的快

更新下最新版本,顺便留个记录



目前最新版是3.3.0,github地址:
https://github.com/greenrobot/greenDAO


第一步首先打开项目gradle,加入配置:

classpath 'org.greenrobot:greendao-gradle-plugin:3.3.0'

整体如下:

buildscript {
    ext.kotlin_version = '1.3.71'
    repositories {
        google()
        jcenter()
        
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.6.3'
        classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"

        classpath 'org.greenrobot:greendao-gradle-plugin:3.3.0'

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        google()
        jcenter()
        
    }
}



然后在app的gradle加入引用:

implementation 'org.greenrobot:greendao:3.3.0'



混淆配置加入:

-keepclassmembers class * extends org.greenrobot.greendao.AbstractDao {
public static java.lang.String TABLENAME;
}
-keep class **$Properties { *; }

# If you DO use SQLCipher:
-keep class org.greenrobot.greendao.database.SqlCipherEncryptedHelper { *; }

# If you do NOT use SQLCipher:
-dontwarn net.sqlcipher.database.**
# If you do NOT use RxJava:
-dontwarn rx.**



另外greendao还需要配置一下版本、目录,同样在app的gradle中配置。

首先在第一行加入:

apply plugin: 'org.greenrobot.greendao'

然后加入配置:

    greendao {
        schemaVersion 1
        daoPackage 'com.xxx.xxx.db.gen'
        targetGenDir 'src/main/java'
    }

schemaVersion是版本号
daoPackage是自动生成的数据库相关类的包名
targetGenDir是相关类的目录



基本配置完毕

然后就可以建立我们需要的实体类了
为了方便,目录就也放在db下了,新建一个bean目录,在其下新建类DataBean:


import org.greenrobot.greendao.annotation.Entity;
import org.greenrobot.greendao.annotation.Id;

@Entity
public class DataBean {

    @Id(autoincrement = true)
    Long rid;

    String name;

}

内容很简单,里面只有两个属性,id和name
其中类名要用Entity注解,表示这个就是需要的实体类
id注解就是主键声明,autoincrement代表自增

写完后,点一下构建,也就是Make Project,就会看到这个类被自动扩充了,同时gen目录下也多了三个文件,这就代表配置没有问题了



顺便一说,Entity不支持kotlin,或者是我没找到正确的方式,哪位知道的话阔以告诉我一声

写完了Entity之后,我们还需要一个整体的Manager类,在db下新建:

package com.emmmm.nice.data.db

import android.content.Context
import com.emmmm.nice.data.db.gen.DaoMaster
import com.emmmm.nice.data.db.gen.DaoSession

object DbManager {

    private lateinit var mDaoMaster: DaoMaster
    private lateinit var mDaoSession: DaoSession

    fun initDb(context: Context) {
        val devOpenHelper = DaoMaster.DevOpenHelper(context, "test.db", null)
        mDaoMaster = DaoMaster(devOpenHelper.writableDatabase)
        mDaoSession = mDaoMaster.newSession()
    }

    fun getDaoSession(): DaoSession {
        return mDaoSession
    }

}

用kotlin比较简约,java的注意单例

然后,我们再建立一个具体的数据库操作类,对应前面的dataBean,放在db.dao下:

import com.emmmm.nice.data.db.DbManager
import com.emmmm.nice.data.db.bean.DataBean
import java.lang.Exception

class DataDao {

    fun add(data: DataBean): Boolean {
        return try {
            DbManager.getDaoSession().dataBeanDao.insertOrReplace(data)
            true
        } catch (e: Exception) {
            false
        }
    }

    fun queryAll(): List<DataBean> {
        return DbManager.getDaoSession().dataBeanDao.loadAll()
    }


    fun deleteById(id: Long): Boolean {
        return try {
            DbManager.getDaoSession().dataBeanDao.deleteByKey(id)
            true
        } catch (e: Exception) {
            false
        }
    }

    fun clear(): Boolean {
        return try {
            DbManager.getDaoSession().dataBeanDao.deleteAll()
            true
        } catch (e: Exception) {
            false
        }
    }

}

很简单的增删改查

我们在DbManager里再加入一个新方法:

    fun getDataDao() = DataDao()



例如新增一条记录,调用就是:

    DbManager.getDataDao().add(DataBean("Test"))

基本的使用这样就ok了,方便快捷

上一篇下一篇

猜你喜欢

热点阅读