前言
最近刚好有点时间,就想重温一下Android 数据库的相关知识。以前一直使用GreenDao,感觉操作起来代码比较冗余。就准备研究一下另外一种框架DBFlow。
DBFlow
偶然发现DBFlow ORM库,发现是采用注解和注解处理器的术,性能强大而稳定,关键是可以省略到大量冗余的数据库代码。
DBFlow配置
1.在project的build里面
repositories {
mavenCentral()
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:2.2.2'
classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
}
}
2.添加仓库托管地址
allprojects {
repositories {
jcenter()
maven { url "https://jitpack.io" }
}
}
3.在moudel的build.gradle中添加
添加依赖
dependencies {
apt 'com.github.Raizlabs.DBFlow:dbflow-processor:${dbflow_version}'
compile "com.github.Raizlabs.DBFlow:dbflow-core:${dbflow_version}"
compile "com.github.Raizlabs.DBFlow:dbflow:${dbflow_version}"
// sql-cipher database encyrption (optional)
compile "com.github.Raizlabs.DBFlow:dbflow-sqlcipher:${dbflow_version}"
}
使用
1.新建一个类继承application 在oncreat里面初始化
/**
* Created by Ruomiz on 2017/4/19 0019
*/
public class AppManager extends Application{
@Override
public void onCreate() {
super.onCreate();
FlowManager.init(this);
}
}
2.在Manifest中添加
<application
android:name=".AppManager"
....>
3.创建数据库 自定创建一个类,定义数据库的名称 版本。
/**
* Created by Ruomiz on 2017/4/19 0019
*/
@Database(name = DBFlowDataBase.NAME, version = DBFlowDataBase.VERSION)
public class DBFlowDataBase {
//数据库名称
public static final String NAME = "RuomizDataBase";
//数据库版本
public static final int VERSION = 1;
}
4.创建一个model文件 继承BaseModel,继承BaseModel中有数据库的基本操作。
/**
* Created by Ruomiz on 2017/4/19 0019
*/
@Table(database = DBFlowDataBase.class) //上面自己创建的类(定义表的名称 版本)
public class DBFlowModel extends BaseModel{
@PrimaryKey(autoincrement = true) //主键 //autoincrement 开启自增
public int id;
@Column //表示一栏 一列
public String name; //自己需要存储的字段
@Column
public int age;
@Column
public String address;
@Column
public int phone;
}
5.写完数据库对象以后 build——make project 然后在 app /build / generated / source / apt / debug / packagename /…下面生成一些文件如下图:
6 数据库的增删改查
DBFlowModel dbFlowModel = new DBFlowMod();
dbFlowModel.name = "Ruomiz";
dbFlowModel.address = "Wuhan";
dbFlowModel.age = "100";
dbFlowModel.phone = "13333333333";
dbFlowModel.save();
//dbFlowModel.update();
//dbFlowModel.delete();
//dbFlowModel.insert();
7.查询
//根据name 单个查询
DBFlowModel dbFlowModel = new Select().from(DBFlowModel.class).where(DBFlowModel_Table.name.is("Ruomiz")).querySingle();
//单个查询
DBFlowDataBase dbFlowDataBase = new Select().from(DBFlowDataBase.class).querySingle();
//返回所有结果
List<DBFlowDataBase> dbFlowDataBases = new Select().from(DBFlowDataBase.class).queryList();
8.到此就已经成功实现DBFlow的简单操作了。版本更新暂时还没有去了解。感兴趣的可以去官方教程查看(上面贴了链接)。以后相关项目将会使用DBFlow,有相关深入将继续总结。