Android數(shù)據(jù)庫greenDAO配置與使用介紹
不知不覺發(fā)現(xiàn)都快一個(gè)月沒有寫點(diǎn)東西了,自己最近也是忙于工作與生活當(dāng)中,這個(gè)月經(jīng)歷了很多事情,有開心的也有悲傷的。還好一切都過來了,空下來時(shí)想著寫點(diǎn)什么好呢,就想著把工作中自己比較喜歡使用的一款有關(guān)數(shù)據(jù)庫的開源框架greenDAO,分享下自己的使用過程。
greenDAO是一個(gè)針對(duì)Android的輕而快速的ORM,它將對(duì)象映射到SQLite數(shù)據(jù)庫。由于對(duì)Android進(jìn)行了高度優(yōu)化,greenDAO提供了出色的性能,并且消耗了最少的內(nèi)存。
build.gradle配置
buildscript {
repositories {
jcenter()
mavenCentral()
}dependencies {
classpath 'com.android.tools.build:gradle:2.3.1'
classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2'
}
}apply plugin: 'com.android.application'
apply plugin: 'org.greenrobot.greendao'android {
buildToolsVersion '25.0.2'
compileSdkVersion 25defaultConfig {
applicationId "org.greenrobot.greendao.example"
minSdkVersion 15
targetSdkVersion 25
versionCode 1
versionName "3"testInstrumentationRunner "android.test.InstrumentationTestRunner"
}
}greendao {
schemaVersion 1000
}dependencies {
compile 'org.greenrobot:greendao:3.2.2'// 這里當(dāng)我們使用加密的數(shù)據(jù)庫時(shí)就必須添加這條依賴
compile 'net.zetetic:android-database-sqlcipher:3.5.6'compile 'com.android.support:appcompat-v7:25.3.1'
compile 'com.android.support:recyclerview-v7:25.3.1'
}uploadArchives.enabled = false
數(shù)據(jù)庫初始化
配置成功后,我們需要?jiǎng)?chuàng)建一個(gè)實(shí)體類用來生成對(duì)應(yīng)的表,@Entity表示這個(gè)實(shí)體類一會(huì)會(huì)在數(shù)據(jù)庫中生成對(duì)應(yīng)的表,@Id表示該字段是id(設(shè)置Long類型表示id會(huì)自動(dòng)增長):
@Entity
public class Province {
@Id
private Long id;
private String provinceName;
private String provinceCode;
}寫完這些之后將項(xiàng)目進(jìn)行編譯:Build—Make Project,編譯成功之后系統(tǒng)會(huì)幫助我們生成相應(yīng)的構(gòu)造方法和get/set方法,并且還會(huì)在我們的包下生成DaoMaster和DaoSession。下面我們就可以對(duì)數(shù)據(jù)庫進(jìn)行初始化了:
public class App extends Application {
//這里我們定義一個(gè)標(biāo)志,從而去切換數(shù)據(jù)庫的標(biāo)準(zhǔn)模式和加密模式
public static final boolean ENCRYPTED = true;
private DaoSession daoSession;
@Override
public void onCreate() {
super.onCreate();
DevOpenHelper helper = new DevOpenHelper(this, ENCRYPTED ? "province-db-encrypted" : "province-db");
Database db = ENCRYPTED ? helper.getEncryptedWritableDb("super-secret") : helper.getWritableDb();
daoSession = new DaoMaster(db).newSession();
}
public DaoSession getDaoSession() {
return daoSession;
}
}如果我們想要操作實(shí)體類是需要要通過DAO來操作,比如我們想要操作Province實(shí)體類,那我們必須先得到一個(gè)ProvinceDao,通過ProvinceDao我們可以對(duì)數(shù)據(jù)庫進(jìn)行增刪改查等操作:
private ProvinceDao provinceDao;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_mine_fix_school);
DaoSession daoSession = ((App) getApplication()).getDaoSession();
provinceDao = daoSession.getProvinceDao();
}添加數(shù)據(jù)
List<Province> provinceList = provinceDao.queryBuilder().build().list();
if (provinceList.size() > 0) {
//數(shù)據(jù)庫有數(shù)據(jù)時(shí)進(jìn)行處理
}else {
//數(shù)據(jù)庫無數(shù)據(jù)時(shí),獲取網(wǎng)絡(luò)數(shù)據(jù)進(jìn)行數(shù)據(jù)存儲(chǔ)
api.areas(areaCode)
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new MySubscriber<List<Province>>() {
@Override
public void onNext(List<Province> provinceList) {
for (Province province : provinceList) {
//插入數(shù)據(jù)
provinceDao.insert(province);
}
});
}刪除數(shù)據(jù)
其實(shí)刪除數(shù)據(jù)和修改數(shù)據(jù)是一樣的思路,我們要先查找到數(shù)據(jù),然后再對(duì)數(shù)據(jù)進(jìn)行操作:
for (Province province : provinceList) {
//刪除數(shù)據(jù)
provinceDao.delete(province);
}修改數(shù)據(jù)
這里我只添加了一個(gè)查詢條件,就是是id于等于10,最后的unique表示只查詢一條數(shù)據(jù)出來即可:
Province province = provinceDao.queryBuilder().where(ProvinceDao.Properties.ProvinceCode.eq(10)).build().unique();
if (province == null) {
//用戶不存在
}else {
province.setProvinceName("修改浙江省");
//修改數(shù)據(jù)
provinceDao.update(province);
}查詢數(shù)據(jù)
其實(shí)上面刪除和修改都已經(jīng)涉及到查詢了,查詢里邊有許多非常好用的函數(shù),這里我只用到了一個(gè)between表示查詢id介于10到20之間的數(shù)據(jù)
List<Province> provinces = provinceDao.queryBuilder().where(ProvinceDao.Properties.ProvinceCode.between(10, 20)).build().list();
for (Province province : provinces) {
//輸出查詢內(nèi)容
Log.d("TAG","search:" + province.getProvinceName());
}補(bǔ)充
- eq:等于
- notEq:不等于
- gt:大于
- lt:小于ge:大于等于
- le:小于等于
- between:在某個(gè)數(shù)值之間的范圍
結(jié)束
好了,到這里greenDAO的一些簡單的功能就可以實(shí)現(xiàn)了,在工作的過程中用到了許多數(shù)據(jù)庫,無論是自己用原生的去寫,還是去使用一些開源框架。到現(xiàn)在感覺greenDAO應(yīng)該算是很好用的一款開源框架,自己也很是喜歡。更想進(jìn)一步的去探究它的奧秘。
到此這篇關(guān)于Android數(shù)據(jù)庫greenDAO配置與使用介紹的文章就介紹到這了,更多相關(guān)Android greenDAO內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android自定義webView頭部進(jìn)度加載效果
這篇文章主要介紹了Android自定義webView頭部進(jìn)度加載效果,小編畫一條進(jìn)度線,然后加載webview上面,具體實(shí)現(xiàn)代碼大家參考下本文2017-11-11
Android使用Jni實(shí)現(xiàn)壓力鍋數(shù)據(jù)檢測(cè)效果示例
這篇文章主要介紹了Android使用Jni實(shí)現(xiàn)壓力鍋數(shù)據(jù)檢測(cè)效果,涉及Android結(jié)合Jni實(shí)現(xiàn)進(jìn)度條模擬壓力鍋數(shù)據(jù)監(jiān)測(cè)效果的相關(guān)操作技巧,需要的朋友可以參考下2017-12-12
21天學(xué)習(xí)android開發(fā)教程之MediaPlayer
21天學(xué)習(xí)android開發(fā)教程之MediaPlayer,MediaPlayer可以播放音頻和視頻,操作相對(duì)簡單,感興趣的小伙伴們可以參考一下2016-02-02
解決Error:All flavors must now belong to a named flavor dimens
這篇文章主要介紹了解決Error:All flavors must now belong to a named flavor dimension. Learn more at https://d.android.com,需要的朋友可以參考下2017-11-11
Android里實(shí)現(xiàn)退出主程序的提示代碼
當(dāng)用戶選擇"確定",就退出當(dāng)前的對(duì)話框。其中,有個(gè)很重要的函數(shù),Activity.finish(),通過調(diào)用這個(gè)函數(shù),退出當(dāng)前運(yùn)行的整個(gè)Android程序2013-06-06
Android中解決頁簽手指按下從左到右滑動(dòng)的bug
有一種方法可以阻止父層的View截獲touch事件,就是調(diào)用 getParent().requestDisallowInterceptTouchEvent(true);方法。這篇文章給大家介紹了Android中解決頁簽手指按下從左到右滑動(dòng)的bug,一起看看吧2016-10-10
解決NDK開發(fā)中Eclipse報(bào)錯(cuò)Unresolved inclusion jni.h的最終解決方法(已測(cè))
這篇文章主要介紹了解決NDK開發(fā)中Eclipse報(bào)錯(cuò)Unresolved inclusion jni.h的最終方法,需要的朋友可以參考下2016-12-12
Flutter Recovering Stream Errors小技巧
這篇文章主要為大家介紹了Flutter Recovering Stream Errors小技巧,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12

