GreenDao(2)--使用

上一篇講了GreenDao的配置,本篇著重于API的各種使用,并附上Demo。

類的關系

大家還記得上一篇講到的代碼自動生成的四個類,DaoMaster,DaoSession,Dao,User,排除最后一個User實體類不說,其他三個的關系應該是非常明確的。

類圖

從圖上看出,得到User對象的步驟。其中還有些細節需要說明。

獲取DaoMaster

用過數據庫的程序圓都清楚,我們需要DaoSession對象來進行對數據庫的增刪改查。

DaoMaster中有newSession()的方法可以幫我們實現。

所以我們應該先實例化DaoMaster,具體代碼是

public DaoMaster(SQLiteDatabase db) {
    super(db, SCHEMA_VERSION);
    registerDaoClass(UserDao.class);
}

噢,需要一個SQLiteDatabase實例,請拼命想一想怎么獲取一個SQLiteDatabase實例?

沒錯,通過SQLiteOpenHelper,再仔細看一下DaoMaster,好像已經提供了抽象類OpenHelper繼承了SQLiteOpenHelper

Cool!

可以獲取DevOpenHelper,具體代碼是

     /**
     * WARNING: Drops all table on Upgrade! Use only during development.
     */
    public static class DevOpenHelper extends OpenHelper {
        public DevOpenHelper(Context context, String name, CursorFactory factory) {
            super(context, name, factory);
        }

        @Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
            Log.i("greenDAO", "Upgrading schema from version " + oldVersion + " to " + newVersion + " by dropping all tables");
            dropAllTables(db, true);
            onCreate(db);
        }
    }

先不管警告的注釋(當數據庫升級的時候會刪除所有表,僅限于開發時使用)。

只要簡單兩行代碼

 DaoMaster.DevOpenHelper helper = new DaoMaster.DevOpenHelper(context, DB_NAME, null);
DaoMaster daoMaster = new DaoMaster(mHelper.getReadableDatabase());
//也可以使用mHelper.getWritableDatabase();

注意:getReadabledatabase()與getWritableDatabase()其實返回的實例都是一樣的,只是當內存空間不足的時候,就不能繼續寫入數據,更為重要的是,它們都是耗時耗時耗時操作!更為詳細的解釋

獲取DaoSession

接著,我們來獲取DaoSession

DaoSession daoSession = daoMaster.newSession();
//異步查詢,異步查詢,異步查詢
AsyncSession asyncSession = daoSession.startAsyncSession();

夠簡單嗎?獲得DaoSession后可以干什么?其實增刪改查的基本功能已經齊全。
只是有三個缺點:

  • 顆粒度太大
  • API不是很方便
  • 官網注釋說只是用于快捷操作

所以UserDao登場吧

獲取UserDao

UserDao userDao = daoSession.getUserDao();

好了,下面就可以隨心所欲地操作數據庫了。

操作數據庫

/**
 * 插入一個User對象
 *
 * @param user
 * @return 插入對象的列id
 */
public long insert(User user) {
    UserDao userDao = getUserDao();
    return userDao.insert(user);
}

查查查***重點

具體方法有

  • queryXXX(...),指明各種條件
  • 使用QueryBuilder(單次查詢),Query(多次查詢)
  • 其他等

這里著重講QueryBuilderQuery,個人用得非常順手,因為自己對SQL語句并不喜歡,so...

看一個簡單例子

/**
 * 通過id取得用戶。此處使用QueryBuider,并沒有構造Query
 *
 * @param id
 * @return
 */
public User getUserById(long id) {
    UserDao userDao = getUserDao();
    //獲取QueryBuilder
    QueryBuilder qb = userDao.queryBuilder();
    //聲明條件,屬性在UserDao中已經存在
    qb.where(UserDao.Properties.Id.eq(id));
    //返回唯一數據
    return (User) qb.unique();
}

QueryBuilder只是用來創建Query而已,Query更使用于相同的查詢,所以QueryBuilder就不要隨便用了。

Quert特點如下

  • Query通過QueryBuilder.build()獲取,它是使用Builder模式設計的,支持多次查詢多線程查詢

      //實際按照要求具體操作
      Query<User> query = userDao.queryBuilder().orderDesc().where().count().build();
      //返回單一結果
      query.unique()
      //返回一個非null的實體。否則就會拋出一個DaoException。
      query.uniqueOrThrow()
      //所有查詢都加載到內存
      query.list();
      //實體按照需求加載進入內存。一旦列表中的一個元素被第一次訪問,它將被加載同時緩存以便以后使用。必須close。
      query.listLazy();
      //多線程查詢,為當前線程獲取一個Query實例
      query.forCurrentThread();
    
  • 支持equal,in,between等等一系列比較符

  • Query可重用

先創建如下Query,根據id = 123和age = 10進行查找(示例)

    UserDao userDao = getUserDao();
    QueryBuilder<User> queryBuilder = userDao.queryBuilder().where(UserDao.Properties.Id.eq(123));
    queryBuilder.where(UserDao.Properties.Age.eq(10)).unique();
    Query query = queryBuilder.build();
    query.unique();

下一次同樣需要根據id = 321和age = 100來進行查找,就可以

//設置id和age的值
query.setParameter(321, 100);
//返回唯一結果
//query.unique()
//設置多個查找目標
query.setParameter(111, 180);
//返回list
query.list();

注意:當Query沒有返回語氣結果,故障排查可以設置QueryBuilder.LOG_SQL = true;QueryBuilder.LOG_VALUES = true;,打印出SQL語句

更多高級用法請查看官方API文檔

基本原則是根據主鍵來修改,比較簡單的兩種情況是

  • 已知主鍵

直接能用API的都基本上已知主鍵的

    /**
     * 更新user信息
     *
     * @param newUser 新User,主鍵必須存在
     */
    public void update(User newUser) {
        UserDao userDao = getUserDao();
        userDao.update(newUser);
    }
  • 未知主鍵,知道其他值

先根據主鍵查找(復習查找的知識),再重復情況一

同理,跟改操作基本一致。

   /**
     * 根據主鍵刪除User
     *
     * @param id User的主鍵Id
     */
    public void deleteUserById(long id) {
        UserDao userDao = getUserDao();
        userDao.deleteByKey(id);
    }

總結

GreenDao給我們簡化了編寫大量重復代碼的步驟,作為輕量級的ORM框架速度飛快,值得深入學習。

GreenDao底層并不保證線程安全,這意味著多線程環境下還需要我們程序圓來控制 ;)

源碼戳這里

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

推薦閱讀更多精彩內容

  • GreenDao 介紹:greenDAO是一個對象關系映射(ORM)的框架,能夠提供一個接口通過操作對象的方式去操...
    小董666閱讀 739評論 0 1
  • greenDAO greenDAO 是一個將對象映射到 SQLite 數據庫中的輕量且快速的 ORM 解決方案。它...
    蕉下孤客閱讀 16,112評論 18 104
  • 1. Java基礎部分 基礎部分的順序:基本語法,類相關的語法,內部類的語法,繼承相關的語法,異常的語法,線程的語...
    子非魚_t_閱讀 31,722評論 18 399
  • 1. 什么是greenDao 弄明白greenDao之前我們應該先了解什么是ORM(Object Relation...
    看一季殘花落幕閱讀 2,524評論 0 4
  • Dijkstra 模板一(map數組模擬鄰接表) 處理小圖速度相對較快。內存占用較小,對重邊優化較差。 模板二(鏈...
    染微言閱讀 548評論 0 0