iOS 平臺 SQLite 性能優(yōu)化

開始

在 ios 平臺,數(shù)據(jù)永久化的存儲方式就那么幾種莽龟,比如說 coredata蠕嫁,比如說realm,還有nosql的幾種方案毯盈,但是很遺憾剃毒,nosql的幾種方案支持的功能都還是太少,這樣就讓對它們的選擇顯得十分雞肋——畢竟搂赋,如果是簡單的應用的話赘阀,那就還不如其他方案來的方便快捷——雖然nosql是趨勢。

這次我們來談談另一種比較常見的儲存方案——sqlite厂镇,這個東西很厲害纤壁,它是一個用c實現(xiàn)的無需服務器的sql框架,它就一個文件配合框架就可以實現(xiàn)一個簡單的數(shù)據(jù)庫了捺信,擁有大部分數(shù)據(jù)庫的查詢功能酌媒,性能也還不錯。

需求

一般使用的話迄靠,sqlite的默認配置也是足夠了的秒咨,但有一些情況下,我們還是需要更快的體驗——比如作為輸入法的詞庫的時候掌挚。很多人覺得雨席,用sqlite很快,但作為輸入法的詞庫就顯然太慢了吠式,難道sqlite就不能更快一步嗎陡厘?當然可以,sqlite的默認配之為了適應大部分人的使用環(huán)境所以設置的十分保守特占,我們可以讓它更快糙置。

Pragma

Pragma 是 sqlite 特有的一個配置語句,與之配合的有一些對應的參數(shù)是目,我們在連接數(shù)據(jù)庫后可以對其進行修改谤饭,但下次連接的時候,還是需要再次配置的。

你可以在這里看到完整的所有 Pragma 參數(shù)揉抵,不過對性能有重大影響的參數(shù)也就那么幾個亡容,不是很多的。

執(zhí)行 pragma 就像你在 sqlite 里執(zhí)行 sql 語句一樣冤今,沒有返回值闺兢。

page_size

1

PRAGMApage_size=4096

大小必須是2的倍數(shù),一般來說戏罢,現(xiàn)在應該都是默認4096了列敲,但如果不是,那你就手動設置一下帖汞,總而言之戴而,你最好把它設置為與你系統(tǒng)硬盤的分頁大小。

synchronous

1

PRAGMAsynchronous=OFF

關閉同步翩蘸,數(shù)據(jù)庫只有在設備突然斷電之類情況下可能導致數(shù)據(jù)庫損壞——嗯所意,這種情況,我覺得可以接受催首。

locking_mode

1

PRAGMAlocking_mode=EXCLUSIVE

當不需要同時有多個進程同時訪問數(shù)據(jù)庫時(我們就在自己的app里訪問數(shù)據(jù)庫而已)那就不需要默認的normal扶踊,設定鎖定模式為exclusive模式,可以保證同一時間只有一個進程訪問數(shù)據(jù)庫郎任,這樣可以避免不必要的沖突控制秧耗,增加數(shù)據(jù)庫速度。

journal_mode

1

PRAGMAjournal_mode=OFF

日志能夠保證數(shù)據(jù)提交的完整性舶治,一旦提交出現(xiàn)問題分井,數(shù)據(jù)庫就可以實現(xiàn)回滾。不過霉猛,現(xiàn)在大部分情況下ios的穩(wěn)定性已經(jīng)足夠尺锚,如果你甚至都不會給數(shù)據(jù)庫寫入內容,那么干脆把日志模式關閉好了惜浅。這樣可以大大加快sqlite的速度瘫辩。

cache_size

1

PRAGMAcache_size=40960

這個緩存,默認是0坛悉,也有不少人推薦1伐厌,我建議你自己多測試幾次,我自己的感受是有和沒有區(qū)別有點裸影,但大小好像沒啥區(qū)別了……

mmap_size

1

PRAGMAmmap_size=40960

配置內存映射挣轨,但實際上好像并沒有開啟,這取決于你的sqlite版本空民。

query_only

1

PRAGMAquery_only=1

如果你和我一樣只是用來查詢刃唐,那么就開啟這個選項。

單件模式

說完了參數(shù)配置界轩,我們再來說說其他方面画饥,比如整體的使用姿勢。如果說你在整個應用中都不會有其他進程訪問數(shù)據(jù)庫(一般也不應該有)浊猾,那么就做一個單件模式抖甘,然后保持長鏈接就好了,并沒有必要一直持續(xù)地連接和斷開葫慎,同時還可以避免你意外地同時去爭奪數(shù)據(jù)庫資源造成數(shù)據(jù)的丟失和文件損壞衔彻。

比如說,這樣:

1

2

3

4

5

6

7classModelManager{

privateinit(){}

staticletsharedInstance:ModelManager?=ModelManager()

……

}

索引

恰當?shù)貫槟阈枰?jīng)常查詢的字段進行索引偷办,并且避免使用太復雜的sql語句以確保查詢會使用索引艰额。一個有效的測試方式是使用 sqlite 內置的explain功能查看語句的執(zhí)行流程,如果其中包含idx椒涯,那基本差不多柄沮。

使用 explain 來查看sql語句的預計執(zhí)行過程

避免不恰當?shù)?sql 語句

一般來說,你應該只獲取你要獲取的內容废岂,不要去做SELECT*FROM這一類腦殘的語句祖搓,同時,在獲取內容的時候湖苞,比如你可能寫的是這樣的:

1

resultSet.stringForColumn("Code")

如果是大量查詢拯欧,那么你最好這樣來寫:

1

resultSet.string(forColumnIndex:0)

使用字段索引來獲取內容,可以避免查找财骨,大大加快取值速度镐作。

創(chuàng)建表

創(chuàng)建表也有優(yōu)化的地方可以說說,比如如果你的字段能非空隆箩,就非空滑肉,如果能唯一那自然就最好了!


轉自 : https://www.logcg.com/archives/2316.html

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末摘仅,一起剝皮案震驚了整個濱河市靶庙,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌娃属,老刑警劉巖六荒,帶你破解...
    沈念sama閱讀 221,695評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異矾端,居然都是意外死亡掏击,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評論 3 399
  • 文/潘曉璐 我一進店門秩铆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來砚亭,“玉大人灯变,你說我怎么就攤上這事⊥北欤” “怎么了添祸?”我有些...
    開封第一講書人閱讀 168,130評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長寻仗。 經(jīng)常有香客問我刃泌,道長,這世上最難降的妖魔是什么署尤? 我笑而不...
    開封第一講書人閱讀 59,648評論 1 297
  • 正文 為了忘掉前任耙替,我火速辦了婚禮,結果婚禮上曹体,老公的妹妹穿的比我還像新娘俗扇。我一直安慰自己,他們只是感情好箕别,可當我...
    茶點故事閱讀 68,655評論 6 397
  • 文/花漫 我一把揭開白布狐援。 她就那樣靜靜地躺著,像睡著了一般究孕。 火紅的嫁衣襯著肌膚如雪啥酱。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,268評論 1 309
  • 那天厨诸,我揣著相機與錄音镶殷,去河邊找鬼。 笑死微酬,一個胖子當著我的面吹牛绘趋,可吹牛的內容都是我干的。 我是一名探鬼主播颗管,決...
    沈念sama閱讀 40,835評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼陷遮,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了垦江?” 一聲冷哼從身側響起帽馋,我...
    開封第一講書人閱讀 39,740評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎比吭,沒想到半個月后绽族,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,286評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡衩藤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,375評論 3 340
  • 正文 我和宋清朗相戀三年吧慢,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片赏表。...
    茶點故事閱讀 40,505評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡检诗,死狀恐怖匈仗,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情逢慌,我是刑警寧澤悠轩,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站涕癣,受9級特大地震影響,放射性物質發(fā)生泄漏前标。R本人自食惡果不足惜坠韩,卻給世界環(huán)境...
    茶點故事閱讀 41,873評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望炼列。 院中可真熱鬧只搁,春花似錦、人聲如沸俭尖。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽稽犁。三九已至焰望,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間已亥,已是汗流浹背熊赖。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留虑椎,地道東北人震鹉。 一個月前我還...
    沈念sama閱讀 48,921評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像捆姜,于是被迫代替她去往敵國和親传趾。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,515評論 2 359

推薦閱讀更多精彩內容