Android數(shù)據(jù)庫(kù)greenDAO配置與使用介紹
不知不覺(jué)發(fā)現(xiàn)都快一個(gè)月沒(méi)有寫(xiě)點(diǎn)東西了,自己最近也是忙于工作與生活當(dāng)中,這個(gè)月經(jīng)歷了很多事情,有開(kāi)心的也有悲傷的。還好一切都過(guò)來(lái)了,空下來(lái)時(shí)想著寫(xiě)點(diǎn)什么好呢,就想著把工作中自己比較喜歡使用的一款有關(guān)數(shù)據(jù)庫(kù)的開(kāi)源框架greenDAO,分享下自己的使用過(guò)程。
greenDAO是一個(gè)針對(duì)Android的輕而快速的ORM,它將對(duì)象映射到SQLite數(shù)據(jù)庫(kù)。由于對(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ù)庫(kù)時(shí)就必須添加這條依賴(lài)
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ù)庫(kù)初始化
配置成功后,我們需要?jiǎng)?chuàng)建一個(gè)實(shí)體類(lèi)用來(lái)生成對(duì)應(yīng)的表,@Entity表示這個(gè)實(shí)體類(lèi)一會(huì)會(huì)在數(shù)據(jù)庫(kù)中生成對(duì)應(yīng)的表,@Id表示該字段是id(設(shè)置Long類(lèi)型表示id會(huì)自動(dòng)增長(zhǎng)):
@Entity public class Province { @Id private Long id; private String provinceName; private String provinceCode; }
寫(xiě)完這些之后將項(xiàng)目進(jìn)行編譯:Build—Make Project,編譯成功之后系統(tǒng)會(huì)幫助我們生成相應(yīng)的構(gòu)造方法和get/set方法,并且還會(huì)在我們的包下生成DaoMaster和DaoSession。下面我們就可以對(duì)數(shù)據(jù)庫(kù)進(jìn)行初始化了:
public class App extends Application { //這里我們定義一個(gè)標(biāo)志,從而去切換數(shù)據(jù)庫(kù)的標(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í)體類(lèi)是需要要通過(guò)DAO來(lái)操作,比如我們想要操作Province
實(shí)體類(lèi),那我們必須先得到一個(gè)ProvinceDao
,通過(guò)ProvinceDao
我們可以對(duì)數(shù)據(jù)庫(kù)進(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ù)庫(kù)有數(shù)據(jù)時(shí)進(jìn)行處理 }else { //數(shù)據(jù)庫(kù)無(wú)數(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è)查詢(xún)條件,就是是id于等于10,最后的unique表示只查詢(xún)一條數(shù)據(jù)出來(lái)即可:
Province province = provinceDao.queryBuilder().where(ProvinceDao.Properties.ProvinceCode.eq(10)).build().unique(); if (province == null) { //用戶(hù)不存在 }else { province.setProvinceName("修改浙江省"); //修改數(shù)據(jù) provinceDao.update(province); }
查詢(xún)數(shù)據(jù)
其實(shí)上面刪除和修改都已經(jīng)涉及到查詢(xún)了,查詢(xún)里邊有許多非常好用的函數(shù),這里我只用到了一個(gè)between表示查詢(xún)id介于10到20之間的數(shù)據(jù)
List<Province> provinces = provinceDao.queryBuilder().where(ProvinceDao.Properties.ProvinceCode.between(10, 20)).build().list(); for (Province province : provinces) { //輸出查詢(xún)內(nèi)容 Log.d("TAG","search:" + province.getProvinceName()); }
補(bǔ)充
- eq:等于
- notEq:不等于
- gt:大于
- lt:小于ge:大于等于
- le:小于等于
- between:在某個(gè)數(shù)值之間的范圍
結(jié)束
好了,到這里greenDAO的一些簡(jiǎn)單的功能就可以實(shí)現(xiàn)了,在工作的過(guò)程中用到了許多數(shù)據(jù)庫(kù),無(wú)論是自己用原生的去寫(xiě),還是去使用一些開(kāi)源框架。到現(xiàn)在感覺(jué)greenDAO應(yīng)該算是很好用的一款開(kāi)源框架,自己也很是喜歡。更想進(jìn)一步的去探究它的奧秘。
到此這篇關(guān)于Android數(shù)據(jù)庫(kù)greenDAO配置與使用介紹的文章就介紹到這了,更多相關(guān)Android greenDAO內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android自定義View的三個(gè)構(gòu)造函數(shù)
這篇文章主要介紹了Android自定義View的三個(gè)構(gòu)造函數(shù),需要的朋友可以參考下2017-06-06Android控件View的文字周?chē)砑訄D標(biāo)
這篇文章主要為大家詳細(xì)介紹了Android控件View的文字周?chē)砑訄D標(biāo),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-03-03Android動(dòng)畫(huà)之逐幀動(dòng)畫(huà)(Frame Animation)基礎(chǔ)學(xué)習(xí)
大家都知道逐幀動(dòng)畫(huà)是一種常見(jiàn)的動(dòng)畫(huà)形式,其原理是在“連續(xù)的關(guān)鍵幀”中分解動(dòng)畫(huà)動(dòng)作,也就是在時(shí)間軸的每幀上逐幀繪制不同的內(nèi)容,使其連續(xù)播放而成動(dòng)畫(huà)。下面我們就來(lái)學(xué)習(xí)下Android中逐幀動(dòng)畫(huà)的基礎(chǔ)知識(shí),有需要的可以參考借鑒。2016-09-09Android開(kāi)發(fā)之TextView控件用法實(shí)例總結(jié)
這篇文章主要介紹了Android開(kāi)發(fā)之TextView控件用法,結(jié)合實(shí)例形式總結(jié)分析了TextView控件常用的屬性設(shè)置及使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-02-02Android?APP啟動(dòng)時(shí)間優(yōu)化介紹
大家好,本篇文章主要講的是Android?APP啟動(dòng)時(shí)間優(yōu)化介紹,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話(huà)記得收藏一下,方便下次瀏覽2021-12-12Android React Native原生模塊與JS模塊通信的方法總結(jié)
這篇文章主要介紹了Android React Native原生模塊與JS模塊通信的方法總結(jié)的相關(guān)資料,需要的朋友可以參考下2017-02-02