(007)mysql索引的設(shè)計(jì)和使用

概述

索引用于快速找出在某個(gè)列中有一特定值的行。不使用索引,MySQL必須從第1條記錄開始然后讀完整個(gè)表直到找出相關(guān)的行炊林。表越大,花費(fèi)的時(shí)間越多卷要。如果表中查詢的列有一個(gè)索引渣聚,MySQL能快速到達(dá)一個(gè)位置去搜尋到數(shù)據(jù)文件的中間独榴,沒有必要看所有數(shù)據(jù)。
??在MySQL中所有的類型數(shù)據(jù)列都可以被索引奕枝,對(duì)相關(guān)列使用索引是提高select操作性能的最佳途徑棺榔。MyISAM和InnoDB存儲(chǔ)引擎的表默認(rèn)創(chuàng)建索引都是BTREE索引。MyISAM還支持全文本索引隘道,該索引可以用于創(chuàng)建全文搜索症歇。默認(rèn)情況下, MEMORY存儲(chǔ)引擎使用HASH索引谭梗,但也支持BTREE索引忘晤。

設(shè)計(jì)索引原則

  1. 最合適索引的列是出現(xiàn)在where子句中的列,或者連接子句中的列激捏。
  2. 使用唯一索引设塔,索引的列的基數(shù)越大,索引效果越好远舅,如存放生日的列具有不同的值闰蛔,很容易區(qū)分各個(gè)行,而記錄性別的列表谊,只含有“m”和“f”钞护,則對(duì)此列進(jìn)行索引沒有多大用處盖喷,因?yàn)椴还芩阉髂膫€(gè)值爆办,都會(huì)大約得出一半的行。
  3. 使用前綴索引课梳,如果對(duì)一個(gè)字符串列進(jìn)行索引距辆,應(yīng)該指定一個(gè)前綴長(zhǎng)度。
  4. 如果索引了多列(復(fù)合索引)暮刃,要遵守最左前綴法則跨算。所謂最左前列,指的是查詢從索引的最左前列開始椭懊,并且不跳過索引中的列诸蚕。
  5. 不要過多的使用索引。每一次的更新氧猬,刪除背犯,插入都會(huì)維護(hù)該表的索引;更多的索引意味著也需要更多的空間 盅抚;過小的表漠魏,建索引可能會(huì)更慢哦 :) (讀個(gè)2頁(yè)的宣傳手冊(cè),你還先去找目錄妄均?)柱锹。
  6. 對(duì)InnoDB存儲(chǔ)引擎的表哪自,記錄默認(rèn)會(huì)按照一定的順序保存,如果有明確定義的主鍵禁熏,則按照主鍵順序保存壤巷,InnoDB表的普通索引都會(huì)保存主鍵的鍵值,所有主鍵盡可能的選擇較短的數(shù)據(jù)類型瞧毙。
  7. 索引列不應(yīng)該作為表達(dá)式的一部分隙笆,即也不能在索引列上使用函數(shù)。

說明:

創(chuàng)建表(friends)與創(chuàng)建(uid和fuid的復(fù)合索引)升筏。


friends表結(jié)構(gòu)
  • 對(duì)第4條說明:


    最左前綴法則

    第2條語句,從索引的第二列開始查找撑柔,使用索引失敗,導(dǎo)致MySQL采用ALL訪問策略您访,即全表查詢.在開發(fā)中铅忿,應(yīng)該盡量避免全表查詢。

  • 對(duì)第7條說明:


    索引不能使用表達(dá)式或函數(shù)

    第2和3條語句都有使用表達(dá)式灵汪,索引派不上用場(chǎng)檀训。

參考

參考1:http://thephper.com/?p=142
參考2:http://my.oschina.net/longniao/blog/110384

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市享言,隨后出現(xiàn)的幾起案子峻凫,更是在濱河造成了極大的恐慌,老刑警劉巖览露,帶你破解...
    沈念sama閱讀 217,657評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件荧琼,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡差牛,警方通過查閱死者的電腦和手機(jī)命锄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來偏化,“玉大人脐恩,你說我怎么就攤上這事≌焯郑” “怎么了驶冒?”我有些...
    開封第一講書人閱讀 164,057評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)韵卤。 經(jīng)常有香客問我骗污,道長(zhǎng),這世上最難降的妖魔是什么怜俐? 我笑而不...
    開封第一講書人閱讀 58,509評(píng)論 1 293
  • 正文 為了忘掉前任身堡,我火速辦了婚禮,結(jié)果婚禮上拍鲤,老公的妹妹穿的比我還像新娘贴谎。我一直安慰自己汞扎,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,562評(píng)論 6 392
  • 文/花漫 我一把揭開白布擅这。 她就那樣靜靜地躺著澈魄,像睡著了一般。 火紅的嫁衣襯著肌膚如雪仲翎。 梳的紋絲不亂的頭發(fā)上痹扇,一...
    開封第一講書人閱讀 51,443評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音溯香,去河邊找鬼鲫构。 笑死,一個(gè)胖子當(dāng)著我的面吹牛玫坛,可吹牛的內(nèi)容都是我干的结笨。 我是一名探鬼主播,決...
    沈念sama閱讀 40,251評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼湿镀,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼炕吸!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起勉痴,我...
    開封第一講書人閱讀 39,129評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤赫模,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后蒸矛,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體瀑罗,經(jīng)...
    沈念sama閱讀 45,561評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,779評(píng)論 3 335
  • 正文 我和宋清朗相戀三年莉钙,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了廓脆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,902評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡磁玉,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出驾讲,到底是詐尸還是另有隱情蚊伞,我是刑警寧澤,帶...
    沈念sama閱讀 35,621評(píng)論 5 345
  • 正文 年R本政府宣布吮铭,位于F島的核電站时迫,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏谓晌。R本人自食惡果不足惜掠拳,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,220評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望纸肉。 院中可真熱鬧溺欧,春花似錦喊熟、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,838評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至聂使,卻和暖如春壁拉,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背柏靶。 一陣腳步聲響...
    開封第一講書人閱讀 32,971評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工弃理, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人屎蜓。 一個(gè)月前我還...
    沈念sama閱讀 48,025評(píng)論 2 370
  • 正文 我出身青樓案铺,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親梆靖。 傳聞我的和親對(duì)象是個(gè)殘疾皇子控汉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,843評(píng)論 2 354

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