关联表: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了,方便快捷