Android SQLite 數據庫筆記

1缓窜、 getWritableDatabase()和getReadableDatabase()區(qū)別

? ? 兩個方法都會返回SQLiteDatabase實例奠蹬。其中getReadableDatabase()是先讀取數據庫粪糙,如果此時磁盤空間滿就會打開失敗于未,當打開失敗時候忿墅,就會繼續(xù)嘗試以只讀的方式打開數據庫。如果磁盤空間夠用就會返回一個可讀寫的數據庫對象剑刑。

????而使用getWritableDatabase()方式打開數據庫媳纬,如果磁盤滿了,數據庫就只讀不能寫了施掏,此時打開數據庫就會報錯。

2茅糜、query和rawQuery的區(qū)別

Cursor?cursor?=?db.rawQuery("select?name?from?***?where?id=?",?new?String[]{"1"});

Cursor?cursor?=?db.query("***",?new?String[]{"name"},?"id=?",?new?String[]{"1"},?null,?null,?null);

上面是兩個分別是query和rawQuery的查詢語句七芭,主要區(qū)別是rawQuery是直接使用SQL語句進行查詢的,也就是第一個參數字符串蔑赘,在字符串內的“狸驳?”會被后面的String[]數組逐一對換掉预明;而query函數是Android自己封裝的查詢API:它的API文檔如下:

public?Cursor??query?(String?table,?String[]?columns,?String?selection,?String[]?selectionArgs,?String?groupBy,?String?having,?String?orderBy)

Query?the?given?table,?returning?a?Cursor?over?the?result?set.

table

The?table?name?to?compile?the?query?against.

columns

A?list?of?which?columns?to?return.?Passing?null?will?return?all?columns,?which?is?discouraged?to?prevent?reading?data?from?storage?that?isn't?going?to?be?used.

selection

A?filter?declaring?which?rows?to?return,?formatted?as?an?SQL?WHERE?clause?(excluding?the?WHERE?itself).?Passing?null?will?return?all?rows?for?the?given?table.

selectionArgs

You?may?include??s?in?selection,?which?will?be?replaced?by?the?values?from?selectionArgs,?in?order?that?they?appear?in?the?selection.?The?values?will?be?bound?as?Strings.

groupBy

A?filter?declaring?how?to?group?rows,?formatted?as?an?SQL?GROUP?BY?clause?(excluding?the?GROUP?BY?itself).?Passing?null?will?cause?the?rows?to?not?be?grouped.

having

A?filter?declare?which?row?groups?to?include?in?the?cursor,?if?row?grouping?is?being?used,?formatted?as?an?SQL?HAVING?clause?(excluding?the?HAVING?itself).?Passing?null?will?cause?all?row?groups?to?be?included,?and?is?required?when?row?grouping?is?not?being?used.

orderBy

How?to?order?the?rows,?formatted?as?an?SQL?ORDER?BY?clause?(excluding?the?ORDER?BY?itself).?Passing?null?will?use?the?default?sort?order,?which?may?be?unordered.

Returns

?A?Cursor?object,?which?is?positioned?before?the?first?entry.?Note?that?Cursors?are?not?synchronized,?see?the?documentation?for?more?details.

而后者query對比前者來講就有一個好處,前者rawQuery你在寫入SQL語句的時候耙箍,有可能寫錯了或者寫漏了什么單詞拼寫錯誤的時候他會出錯撰糠,而后者相對來講出錯的機率就比較小




?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市辩昆,隨后出現的幾起案子阅酪,更是在濱河造成了極大的恐慌,老刑警劉巖汁针,帶你破解...
    沈念sama閱讀 221,198評論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件术辐,死亡現場離奇詭異,居然都是意外死亡施无,警方通過查閱死者的電腦和手機辉词,發(fā)現死者居然都...
    沈念sama閱讀 94,334評論 3 398
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來猾骡,“玉大人瑞躺,你說我怎么就攤上這事⌒讼耄” “怎么了隘蝎?”我有些...
    開封第一講書人閱讀 167,643評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長襟企。 經常有香客問我嘱么,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,495評論 1 296
  • 正文 為了忘掉前任萤晴,我火速辦了婚禮侵状,結果婚禮上,老公的妹妹穿的比我還像新娘冰评。我一直安慰自己,他們只是感情好木羹,可當我...
    茶點故事閱讀 68,502評論 6 397
  • 文/花漫 我一把揭開白布甲雅。 她就那樣靜靜地躺著,像睡著了一般坑填。 火紅的嫁衣襯著肌膚如雪抛人。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,156評論 1 308
  • 那天脐瑰,我揣著相機與錄音妖枚,去河邊找鬼。 笑死苍在,一個胖子當著我的面吹牛绝页,可吹牛的內容都是我干的荠商。 我是一名探鬼主播,決...
    沈念sama閱讀 40,743評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼续誉,長吁一口氣:“原來是場噩夢啊……” “哼莱没!你這毒婦竟也來了?” 一聲冷哼從身側響起酷鸦,我...
    開封第一講書人閱讀 39,659評論 0 276
  • 序言:老撾萬榮一對情侶失蹤饰躲,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后井佑,有當地人在樹林里發(fā)現了一具尸體属铁,經...
    沈念sama閱讀 46,200評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,282評論 3 340
  • 正文 我和宋清朗相戀三年躬翁,在試婚紗的時候發(fā)現自己被綠了焦蘑。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,424評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡盒发,死狀恐怖例嘱,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情宁舰,我是刑警寧澤拼卵,帶...
    沈念sama閱讀 36,107評論 5 349
  • 正文 年R本政府宣布,位于F島的核電站蛮艰,受9級特大地震影響腋腮,放射性物質發(fā)生泄漏。R本人自食惡果不足惜壤蚜,卻給世界環(huán)境...
    茶點故事閱讀 41,789評論 3 333
  • 文/蒙蒙 一即寡、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧袜刷,春花似錦聪富、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,264評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至萧豆,卻和暖如春奸披,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背炕横。 一陣腳步聲響...
    開封第一講書人閱讀 33,390評論 1 271
  • 我被黑心中介騙來泰國打工源内, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人份殿。 一個月前我還...
    沈念sama閱讀 48,798評論 3 376
  • 正文 我出身青樓膜钓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親卿嘲。 傳聞我的和親對象是個殘疾皇子颂斜,可洞房花燭夜當晚...
    茶點故事閱讀 45,435評論 2 359

推薦閱讀更多精彩內容