greenDao的對于表的操作總結(jié)

greenDao的對于表的操作總結(jié):(需要將App卸載重裝诱建,才能走建表語句)

1筒捺、一般要寫一個(gè)DaoUtil,用于獲取對表操作的對象: 在DaoUtil中主要代碼:
DaoMaster.OpenHelper helper = new ......
DaoMaster daoMaster = new DaoMaster(helper.getWritableDatabase());

2酪我、在使用的時(shí)候是先得到一個(gè)daoSession對象棕洋,再進(jìn)行對于數(shù)據(jù)庫中表的操作: DaoSession daoSession = DaoUtil.getDaoSession(context);

3椅挣、對表進(jìn)行執(zhí)行增刪改查:
增加:
①.例如增加:(insertOrReplaceInTx):使用事務(wù)操作晴裹,將給定的實(shí)體集合插入數(shù)據(jù)庫被济,所此實(shí)體存在,則覆蓋:
daoSession.getNotifyEntityDao().insertOrReplaceInTx(mUnreadNoticeList);
②insertInTx:將給定的實(shí)體插入數(shù)據(jù)庫
③insertorReplace(T entity):將給定的實(shí)體插入數(shù)據(jù)庫涧团,若此實(shí)體類存在只磷,則覆蓋。
④save(T entity):將給定的實(shí)體插入數(shù)據(jù)庫泌绣,若實(shí)體存在钮追,則更新。

刪除:
delete(T entity):從數(shù)據(jù)庫中刪除給定的實(shí)體
deleteAll() :刪除數(shù)據(jù)庫中全部數(shù)據(jù)
deleteByKey(K key):從數(shù)據(jù)庫中刪除給定Key所對應(yīng)的實(shí)體
deleteByKeyInTx(java.lang.Iterable<K> keys):使用事務(wù)操作刪除數(shù)據(jù)庫中給定的所有key所對應(yīng)的實(shí)體
deleteByKeyInTx(K... keys):使用事務(wù)操作刪除數(shù)據(jù)庫中給定的所有key所對應(yīng)的實(shí)體
deleteInTx(java.lang.Iterable<T> entities):使用事務(wù)操作刪除數(shù)據(jù)庫中給定實(shí)體集合中的實(shí)體
deleteInTx(T... entities):使用事務(wù)操作刪除數(shù)據(jù)庫中給定的實(shí)體

修改:
update(T entity) :更新給定的實(shí)體
updateInsideSynchronized(T entity, DatabaseStatement stmt, boolean lock)
updateInsideSynchronized(T entity, android.database.sqlite.SQLiteStatement stmt, boolean lock)
updateInTx(java.lang.Iterable<T> entities) :使用事務(wù)操作阿迈,更新給定的實(shí)體
updateInTx(T... entities):使用事務(wù)操作元媚,更新給定的實(shí)體

查詢:使用QueryBuilder自定義查詢實(shí)體,而不是再寫繁瑣的SQL語句苗沧,避免SQL語句出錯(cuò)率刊棕。
官方給的查詢例子:

①List joes = userDao.queryBuilder()
// 查詢的條件
.where(Properties.FirstName.eq("Joe"))
// 返回實(shí)體集合升序排列
.orderAsc(Properties.LastName)
.list();

②QueryBuilder qb = userDao.queryBuilder();
// 查詢的條件
qb.where(Properties.FirstName.eq("Joe"),
qb.or(Properties.YearOfBirth.gt(1970),
qb.and(Properties.YearOfBirth.eq(1970), Properties.MonthOfBirth.ge(10))));
List youngJoes = qb.list();

③其他為分頁等不方便而存在的api:
limit(int):限制查詢返回結(jié)果的數(shù)目
offset(int):設(shè)置查詢結(jié)果的偏移量,此查詢需與limit(int)結(jié)合使用待逞,而不能夠脫離limit(int)單獨(dú)使用

④如果查詢的結(jié)果是多個(gè)(返回的結(jié)果是一個(gè)集合等)
list():所有實(shí)體加載至內(nèi)存甥角,結(jié)果通常是一個(gè)ArrayList
listLazy():實(shí)體在需要時(shí),加載至內(nèi)存识樱,表中的第一個(gè)元素被第一次訪問時(shí)會(huì)被緩存嗤无,下次訪問時(shí),使用緩存
listLazyUncached():任何對列表實(shí)體的訪問懂事從數(shù)據(jù)庫中加載
listIterator():以按需加載的方式來遍歷結(jié)果怜庸,數(shù)據(jù)沒有被緩存

List<NotifyEntity> mUnreadNoticeListFromDB = daoSession.getNotifyEntityDao().queryBuilder().list();

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末当犯,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子割疾,更是在濱河造成了極大的恐慌嚎卫,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,729評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件宏榕,死亡現(xiàn)場離奇詭異拓诸,居然都是意外死亡胸懈,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門恰响,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人涌献,你說我怎么就攤上這事胚宦。” “怎么了燕垃?”我有些...
    開封第一講書人閱讀 169,461評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵枢劝,是天一觀的道長。 經(jīng)常有香客問我卜壕,道長您旁,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,135評(píng)論 1 300
  • 正文 為了忘掉前任轴捎,我火速辦了婚禮鹤盒,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘侦副。我一直安慰自己侦锯,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,130評(píng)論 6 398
  • 文/花漫 我一把揭開白布秦驯。 她就那樣靜靜地躺著尺碰,像睡著了一般。 火紅的嫁衣襯著肌膚如雪译隘。 梳的紋絲不亂的頭發(fā)上亲桥,一...
    開封第一講書人閱讀 52,736評(píng)論 1 312
  • 那天,我揣著相機(jī)與錄音固耘,去河邊找鬼题篷。 笑死,一個(gè)胖子當(dāng)著我的面吹牛玻驻,可吹牛的內(nèi)容都是我干的悼凑。 我是一名探鬼主播,決...
    沈念sama閱讀 41,179評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼璧瞬,長吁一口氣:“原來是場噩夢啊……” “哼户辫!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起嗤锉,我...
    開封第一講書人閱讀 40,124評(píng)論 0 277
  • 序言:老撾萬榮一對情侶失蹤渔欢,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后瘟忱,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體奥额,經(jīng)...
    沈念sama閱讀 46,657評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡苫幢,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,723評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了垫挨。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片韩肝。...
    茶點(diǎn)故事閱讀 40,872評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖九榔,靈堂內(nèi)的尸體忽然破棺而出哀峻,到底是詐尸還是另有隱情,我是刑警寧澤哲泊,帶...
    沈念sama閱讀 36,533評(píng)論 5 351
  • 正文 年R本政府宣布剩蟀,位于F島的核電站,受9級(jí)特大地震影響切威,放射性物質(zhì)發(fā)生泄漏育特。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,213評(píng)論 3 336
  • 文/蒙蒙 一先朦、第九天 我趴在偏房一處隱蔽的房頂上張望缰冤。 院中可真熱鬧,春花似錦喳魏、人聲如沸锋谐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽涮拗。三九已至,卻和暖如春迂苛,著一層夾襖步出監(jiān)牢的瞬間三热,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評(píng)論 1 274
  • 我被黑心中介騙來泰國打工三幻, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留就漾,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,304評(píng)論 3 379
  • 正文 我出身青樓念搬,卻偏偏與公主長得像抑堡,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子朗徊,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,876評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容