您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“Android數(shù)據(jù)庫greenDAO如何配置與使用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Android數(shù)據(jù)庫greenDAO如何配置與使用”吧!
greenDAO是一個(gè)針對(duì)Android的輕而快速的ORM,它將對(duì)象映射到SQLite數(shù)據(jù)庫。由于對(duì)Android進(jìn)行了高度優(yōu)化,greenDAO提供了出色的性能,并且消耗了最少的內(nèi)存。
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
配置成功后,我們需要?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)增長(zhǎ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(); }
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í)刪除數(shù)據(jù)和修改數(shù)據(jù)是一樣的思路,我們要先查找到數(shù)據(jù),然后再對(duì)數(shù)據(jù)進(jìn)行操作:
for (Province province : provinceList) { //刪除數(shù)據(jù) provinceDao.delete(province); }
這里我只添加了一個(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ī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()); }
eq:等于
notEq:不等于
gt:大于
lt:小于ge:大于等于
le:小于等于
between:在某個(gè)數(shù)值之間的范圍
到此,相信大家對(duì)“Android數(shù)據(jù)庫greenDAO如何配置與使用”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。