greenDAO3.2.2簡單教程

一、關于greenDAO

greenDAO應該算是當前最火的數據庫開源框架了,它是一個將對象映射到SQLite數據庫中的輕量且快速的ORM(object / relational mapping)解決方案。

greenDAO-orm

關于greenDAO的其他相關信息可以看官網greenDAO
githubgreenDAO地址官方的配置GreenDAO英文文檔

二、greenDAO理解

DAO的core library中有以下幾個核心類,也是后面常用到的,先來大概了解下他們的結構,不然直接看他們的使用會云里霧里。

Core-Classes
  • DaoMaster:Dao中的管理者。它保存了sqlitedatebase對象以及操作DAO classes(注意:不是對象)。其提供了一些創建和刪除table的靜態方法,其內部類OpenHelper和DevOpenHelper實現了
    SQLiteOpenHelper,并創建數據庫的框架。

  • DaoSession:會話層。操作具體的DAO對象(注意:是對象),比如各種getter方法。

  • Daos:實際生成的某某DAO類,通常對應具體的java類,比如NoteDao等。其有更多的權限和方法來操作數據庫元素。

  • Entities:持久的實體對象。通常代表了一個數據庫row的標準java properties。

三、greenDAO優勢

1、一個精簡的庫
2、性能最大化
3、內存開銷最小化
4、易于使用的 APIs
5、對 Android 進行高度優化
有興趣的可以看下官網的 greenDAO Features

四、greenDAO使用

greenDAO3.0采用注解的方式來定義實體類,通過gradle插件生成相應的代碼。

1,首先在project的gradle文件中引入greenDAO插件,引入之后如下:

// In your root build.gradle file:
buildscript {
    repositories {
        jcenter()
        mavenCentral() // add repository
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.0.0'
        classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2' // add plugin
    }
}

2,然后在module的gradle文件中添加greenDAO的插件,并引入相關類庫,修改之后如下:

// In your app projects build.gradle file:
apply plugin: 'com.android.application'
apply plugin: 'org.greenrobot.greendao' // apply plugin

android {  
    ...  
    ...  
  
    greendao{  
        schemaVersion 1  
        daoPackage 'com.greendao.gen'
        targetGenDir 'src/main/java'  
    }  
} 
dependencies {  
    ...  
    ...  
    implementation 'org.greenrobot:greendao:3.2.2' // add library
} 

在gradle的根模塊中加入上述代碼,就完成了我們的基本配置了。
屬性介紹:
schemaVersion--> 指定數據庫schema版本號,遷移等操作會用到;
daoPackage --> dao的包名,包名默認是entity所在的包;
targetGenDir --> 生成數據庫文件的目錄;

3,創建一個User的實體類

@Entity
public class User {
    @Id 
    private Long id; 
    @Property(nameInDb = "NAME")
    private String name; 
    @Transient 
    private int tempUsageCount; // not persisted  
}
  • @Entity 表示這個實體類一會會在數據庫中生成對應的表,
  • @Id 表示該字段是id,注意該字段的數據類型為包裝類型Long
  • @Property 則表示該屬性將作為表的一個字段,其中nameInDb看名字就知道這個屬性在數據庫中對應的數據名稱。
  • @Transient 該注解表示這個屬性將不會作為數據表中的一個字段。
  • @NotNull 表示該字段不可以為空
  • @Unique 表示該字段唯一。小伙伴們有興趣可以自行研究。

4,MakeProject

編譯項目(Android快捷鍵:Ctrl+F9),User實體類會自動編譯,生成get、set方法并且會在com.greendao.gen目錄下生成三個文件,并且還會在我們的包下生成DaoMaster和DaoSession。

五、greenDAO使用

步驟:即:先創建了一個SQLiteOpenHelper并創建連接到一個具體數據庫;再根據具體的datebase創建一個master對象用于;最后通過master創建一個數據庫的會話操作。

 public class MyApplication extends Application {
 private DaoMaster.DevOpenHelper mHelper;
 private SQLiteDatabase db;
 private DaoMaster mDaoMaster;
 private DaoSession mDaoSession;
 public static MyApplication instances;
 @Override    public void onCreate() {
     super.onCreate();
     instances = this;
     setDatabase();
 }
 public static MyApplication getInstances(){
     return instances;
 }

/**
 * 設置greenDAO
 */
private void setDatabase() {
    // 通過 DaoMaster 的內部類 DevOpenHelper,你可以得到一個便利的 SQLiteOpenHelper 對象。
    // 可能你已經注意到了,你并不需要去編寫「CREATE TABLE」這樣的 SQL 語句,因為 greenDAO已經幫你做了。
    // 注意:默認的 DaoMaster.DevOpenHelper 會在數據庫升級時,刪除所有的表,意味著這將導致數據的丟失。
    // 所以,在正式的項目中,你還應該做一層封裝,來實現數據庫的安全升級。
    mHelper = new DaoMaster.DevOpenHelper(this, "notes-db", null);
    db = mHelper.getWritableDatabase();
    // 注意:該數據庫連接屬于 DaoMaster,所以多個 Session 指的是相同的數據庫連接。 
    mDaoMaster = new DaoMaster(db); 
    mDaoSession = mDaoMaster.newSession();
}
public DaoSession getDaoSession() {
      return mDaoSession;
}
public SQLiteDatabase getDb() {
      return db;
  }
}

獲取UserDao對象:

 UserDao mUserDao = MyApplication.getInstances().getDaoSession().getUserDao();

六、簡單的增刪改查實現:

mUser = new User((long)2,"anye3");
mUserDao.insert(mUser);//添加一個
mUserDao.deleteByKey(id);
mUser = new User((long)2,"anye0803");
mUserDao.update(mUser);
List<User> users = mUserDao.loadAll();
String userName = "";
for (int i = 0; i < users.size(); i++) {
    userName += users.get(i).getName()+",";
}
mContext.setText("查詢全部數據==>"+userName);

更多的操作就不一一介紹了,大家可以根據需要去查找資料;

七、greenDAO中的注解

(一) @Entity 定義實體
@nameInDb 在數據庫中的名字,如不寫則為實體中類名
@indexes 索引
@createInDb 是否創建表,默認為true,false時不創建
@schema 指定架構名稱為實體
@active 無論是更新生成都刷新
(二) @Id
(三) @NotNull 不為null
(四) @Unique 唯一約束
(五) @ToMany 一對多
(六) @OrderBy 排序
(七) @ToOne 一對一
(八) @Transient 不存儲在數據庫中
(九) @generated 由greenDAO產生的構造函數或方法

八、數據庫升級

數據庫的升級其實就兩個步驟我們來看看:
8.1 修改gradle文件
首先在module的gradle文件中修改版本號:

//這里改為最新的版本號  
schemaVersion 2  
targetGenDir 'src/main/java'  

8.2修改實體類

@Entity  
public class User {  
    @Property  
    private int age;  
    @Property  
    private String password;  
    @Id  
    private Long id;  
    @Property(nameInDb = "USERNAME")  
    private String username;  
    @Property(nameInDb = "NICKNAME")  
    private String nickname;  
}

重現編譯項目運行即可。
一般的數據庫升級這樣就可以了,特殊情況可能需要自己編寫數據庫遷移腳本,這種時候可以自定義DBHelper,定義方式如下,注意繼承類:

public class DBHelper extends DaoMaster.OpenHelper {  
    public static final String DBNAME = "lenve.db";  
  
    public DBHelper(Context context) {  
        super(context, DBNAME, null);  
    }  
  
    @Override  
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {  
        super.onUpgrade(db, oldVersion, newVersion);  
    }  
}

可以在onUpgrade方法中進行數據庫的遷移,如果自定義了DBHelper,則數據庫的初始化變為如下方式:

DBHelper devOpenHelper = new DBHelper(this);  
DaoMaster daoMaster = new DaoMaster(devOpenHelper.getWritableDb());  
DaoSession daoSession = daoMaster.newSession();  
userDao = daoSession.getUserDao(); 

九.結束語

總體來說,greenDAO在配置上相對于2.0要簡單的多。
本文 Demo 下載鏈接:greenDAODemo,如果喜歡的話可以star一下。
本教程旨在介紹 greenDAO3.0的基本用法與配置,更高級與詳細的使用,請參見官網如本文有任何問題歡迎指正。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,923評論 6 535
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,740評論 3 420
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,856評論 0 380
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,175評論 1 315
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,931評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,321評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,383評論 3 443
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,533評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,082評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,891評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,067評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,618評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,319評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,732評論 0 27
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,987評論 1 289
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,794評論 3 394
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,076評論 2 375

推薦閱讀更多精彩內容