
前言
最近剛好有點時間,就想重溫一下 Android 數(shù)據(jù)庫的相關(guān)知識。以前一直使用 GreenDao,感覺操作起來代碼比較冗余。就準備研究一下另外一種框架 DBFlow。
DBFlow
偶然發(fā)現(xiàn) DBFlow ORM 庫,發(fā)現(xiàn)是采用注解和注解處理器的術(shù),性能強大而穩(wěn)定,關(guān)鍵是可以省略到大量冗余的數(shù)據(jù)庫代碼。
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.在 module 的 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 里面初始化
public class AppManager extends Application{
@Override
public void onCreate() {
super.onCreate();
FlowManager.init(this);
}
}
2.在 Manifest 中添加
<application
android:name=".AppManager"
....>
3.創(chuàng)建數(shù)據(jù)庫自自己創(chuàng)建一個類,定義數(shù)據(jù)庫的名稱 、版本
@Database(name = DBFlowDataBase.NAME, version = DBFlowDataBase.VERSION)
public class DBFlowDataBase {
//數(shù)據(jù)庫名稱
public static final String NAME = "RuomizDataBase";
//數(shù)據(jù)庫版本
public static final int VERSION = 1;
}
4.創(chuàng)建一個 model 文件 繼承 BaseModel,繼承 BaseModel 中有數(shù)據(jù)庫的基本操作。
@Table(database = DBFlowDataBase.class) //上面自己創(chuàng)建的類(定義表的名稱 版本)
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.寫完數(shù)據(jù)庫對象以后 build——make project 然后在 app /build / generated / source / apt / debug / packagename /... 下面生成一些文件如下圖:

6 數(shù)據(jù)庫的增刪改查
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.查詢
//根據(jù) name 單個查詢
DBFlowModel dbFlowModel = new Select()
.from(DBFlowModel.class)
.where(DBFlowModel_Table.name.is("Ruomiz"))
.querySingle();
//單個查詢
DBFlowDataBase dbFlowDataBase = new Select()
.from(DBFlowDataBase.class)
.querySingle();
//返回所有結(jié)果
List<DBFlowDataBase> dbFlowDataBases = new Select()
.from(DBFlowDataBase.class)
.queryList();
8.到此就已經(jīng)成功實現(xiàn) DBFlow 的簡單操作了。版本更新暫時還沒有去了解,感興趣的可以去官方教程查看(上面貼了鏈接),以后相關(guān)項目將會使用 DBFlow,有相關(guān)深入將繼續(xù)總結(jié)。