之前一直使用SQLite写数据库,前几日用过GreenDao后,相见恨晚。对比的感受就是,SQLite建表,增删改查都需要写很多代码,开发效率低下,并且存取的效率也较低,相比之下,GreenDao建表、使用都很方便,且效率很高,插入和更新的速度都是SQLite的2倍,GreenDao本身不到100k,占用内存也很小。
接下来,我们就来看看,GreenDao到底如何使用。
首先,我们要在项目中集成该框架。在Project : build.gradle中添加仓库和插件。
buildscript {
repositories {
google()
jcenter()
mavenCentral() // 设置maven仓库
}
dependencies {
classpath 'com.android.tools.build:gradle:3.4.1'
classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2' // 增加GreenDao插件
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
然后在Module :build.gradle中增加依赖
apply plugin: 'org.greenrobot.greendao' // 应用插件
dependencies {
implementation fileTree(include: ['*.jar'], dir: 'libs')
//省略其他不相关依赖库...
implementation 'org.greenrobot:greendao:3.2.2'// 添加依赖库
implementation 'net.zetetic:android-database-sqlcipher:3.5.6'//加密库依赖,可选
}
继续在Module :build.gradle中设置数据库属性
greendao {
schemaVersion 1 //数据库版本号
daoPackage 'com.example.pax.printer.db.dao'// 设置DaoMaster、DaoSession、Dao 包名
targetGenDir 'src/main/java'//设置DaoMaster、DaoSession、Dao目录
}
完成以上配置后,同步工程。接下来,我们就开始具体使用GreenDao。先写一个实体类,TransData.java
@Entity
public class TransData {
@Id
private Long id;
private String transType;
private String cardType;
private String amount;
private String traceNo;
private String dateTime;
//生成getter、setter函数,我这边就省略了
}
这边我们用到两个注解,@Entity 表明这个实体类会在数据库中生成一个与之相对应的表,@Id 对应数据表中的 Id 字段。
写好实体类后,我们编译下工程,如果配置成功,就会在我们刚刚设置的目录下生成这些文件:
在Application类中初始化GreenDao:
public class FinancialApplication extends MultiDexApplication{
private static FinancialApplication mApp;
private DaoSession daoSession;
@Override
public void onCreate() {
super.onCreate();
FinancialApplication.mApp = this;
initGreenDao();
}
public static FinancialApplication getApp() {
return mApp;
}
private void initGreenDao(){
DaoMaster.DevOpenHelper openHelper = new DaoMaster.DevOpenHelper(this, "trans_data.db");
SQLiteDatabase sqLiteDatabase = openHelper.getWritableDatabase();
DaoMaster master = new DaoMaster(sqLiteDatabase);
daoSession = master.newSession();
}
public DaoSession getDaoSession() {
return daoSession;
}
}
获取TransDataDao:
DaoSession daoSession = FinancialApplication.getApp().getDaoSession();
private TransDataDao dataDao;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_new_record);
dataDao = daoSession.getTransDataDao();
}
数据库的增删改查:
public void onSaveClick(View view){
TransData transData = new TransData();
transData.setDateTime(getDateTime());
transData.setTransType(transType.getText().toString());
transData.setAmount(amount.getText().toString());
transData.setCardType(cardType.getText().toString());
transData.setTraceNo(transNo.getText().toString());
if(recordId > 0){
transData.setId(recordId);
dataDao.update(transData);//更新数据,使用这个方法记得要传id,不然会出错
}else {
dataDao.insertOrReplace(transData);//增加数据,使用insert(T entity)也一样的
}
}
public void onDelClick(View view){
dataDao.deleteByKey(recordId);//根据id删除数据,还有别的方法,可以自己试一试
}
private TransData getTransData(long id){
return dataDao.loadByRowId(id);//根据id查询数据,查询全部的话用loadAll()
}
到这里,GreenDao的基础使用就介绍完啦。