首頁 > 軟體

Android資料庫greenDAO設定與使用介紹

2023-08-24 18:01:00

不知不覺發現都快一個月沒有寫點東西了,自己最近也是忙於工作與生活當中,這個月經歷了很多事情,有開心的也有悲傷的。還好一切都過來了,空下來時想著寫點什麼好呢,就想著把工作中自己比較喜歡使用的一款有關資料庫的開源框架greenDAO,分享下自己的使用過程。

greenDAO是一個針對Android的輕而快速的ORM,它將物件對映到SQLite資料庫。由於對Android進行了高度優化,greenDAO提供了出色的效能,並且消耗了最少的記憶體。

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 25

    defaultConfig {
        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'

    // 這裡當我們使用加密的資料庫時就必須新增這條依賴
    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

資料庫初始化

設定成功後,我們需要建立一個實體類用來生成對應的表,@Entity表示這個實體類一會會在資料庫中生成對應的表,@Id表示該欄位是id(設定Long型別表示id會自動增長):

@Entity
public class Province {
    @Id
    private Long id;
    private String provinceName;
    private String provinceCode;
    }

寫完這些之後將專案進行編譯:Build—Make Project,編譯成功之後系統會幫助我們生成相應的構造方法和get/set方法,並且還會在我們的包下生成DaoMaster和DaoSession。下面我們就可以對資料庫進行初始化了:

public class App extends Application {
    //這裡我們定義一個標誌,從而去切換資料庫的標準模式和加密模式
    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;
    }
}

如果我們想要操作實體類是需要要通過DAO來操作,比如我們想要操作Province實體類,那我們必須先得到一個ProvinceDao,通過ProvinceDao我們可以對資料庫進行增刪改查等操作:

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) {
            //資料庫有資料時進行處理
        }else {
            //資料庫無資料時,獲取網路資料進行資料儲存
            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) {
                           //插入資料
                           provinceDao.insert(province);
                      }
                });
        }

刪除資料

其實刪除資料和修改資料是一樣的思路,我們要先查詢到資料,然後再對資料進行操作:

    for (Province province : provinceList) {
            //刪除資料
            provinceDao.delete(province);
        }

修改資料

這裡我只新增了一個查詢條件,就是是id於等於10,最後的unique表示只查詢一條資料出來即可:

Province province = provinceDao.queryBuilder().where(ProvinceDao.Properties.ProvinceCode.eq(10)).build().unique();
        if (province == null) {
            //使用者不存在
        }else {
            province.setProvinceName("修改浙江省");
            //修改資料
            provinceDao.update(province);
        }

查詢資料

其實上面刪除和修改都已經涉及到查詢了,查詢裡邊有許多非常好用的函數,這裡我只用到了一個between表示查詢id介於10到20之間的資料

List<Province> provinces = provinceDao.queryBuilder().where(ProvinceDao.Properties.ProvinceCode.between(10, 20)).build().list();
        for (Province province : provinces) {
            //輸出查詢內容
            Log.d("TAG","search:" + province.getProvinceName());
        }

補充

  • eq:等於
  • notEq:不等於
  • gt:大於
  • lt:小於ge:大於等於
  • le:小於等於
  • between:在某個數值之間的範圍

結束

好了,到這裡greenDAO的一些簡單的功能就可以實現了,在工作的過程中用到了許多資料庫,無論是自己用原生的去寫,還是去使用一些開源框架。到現在感覺greenDAO應該算是很好用的一款開源框架,自己也很是喜歡。更想進一步的去探究它的奧祕。

到此這篇關於Android資料庫greenDAO設定與使用介紹的文章就介紹到這了,更多相關Android greenDAO內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com