MySQL索引

目錄

  1. 什么是索引?
  2. 索引類型
  3. 多列索引
  4. 使用最優(yōu)索引
    總結(jié)
    附錄

1. 什么是索引官还?

索引是一種通過(guò)避免查詢時(shí)全表掃描實(shí)現(xiàn)快速得到查詢結(jié)果而建立的數(shù)據(jù)結(jié)構(gòu); 以下這個(gè)例子很好的說(shuō)明了索引的一種實(shí)現(xiàn)以及它如何提升我們的查詢效率遍膜。

假設(shè)數(shù)據(jù)庫(kù)中一個(gè)表有10^6條記錄灼擂,DBMS的頁(yè)面大小為4K,并存儲(chǔ)100條記錄。

如果沒(méi)有索引,查詢將對(duì)整個(gè)表進(jìn)行掃描,最壞的情況下犬庇,如果所有數(shù)據(jù)頁(yè)都不在內(nèi)存,需要讀取10^4個(gè)頁(yè)面侨嘀,如果這10^4個(gè)頁(yè)面在磁盤上隨機(jī)分布臭挽,需要進(jìn)行10^4次I/O,假設(shè)磁盤每次I/O時(shí)間為10ms(忽略數(shù)據(jù)傳輸時(shí)間)咬腕,則總共需要100s(但實(shí)際上要好很多很多)欢峰。

如果對(duì)之建立B-Tree索引,則只需要進(jìn)行l(wèi)og100(10^6)=3次頁(yè)面讀取涨共,最壞情況下耗時(shí)30ms纽帖。^[1]

這就是索引帶來(lái)的效果,很多時(shí)候举反,當(dāng)你的應(yīng)用程序進(jìn)行SQL查詢速度很慢時(shí)懊直,應(yīng)該想想是否可以建索引。

2. 索引類型

MySQL中索引分為:

  • PRIMARY KEY直接通過(guò)設(shè)置主鍵也就建立了索引;
  • UNIQUE一般主要用于保證數(shù)據(jù)的唯一性;
  • INDEX普通索引也是最常使用的索引類型;
  • FULLTEXT主要可用于列類型為(CHAR,VARCHAR,TEXT)的快速匹配查詢^[3]火鼻。
注: FULLTEXT索引僅支持MyISAM引擎, InnoDB引擎需要版本>=MySQL5.6才支持!

WHERE語(yǔ)句使用=,>,<,BETWEEN,IN都可使用索引快速查找到特定的某條或某些記錄室囊。

3. 多列索引

MySQL中也可根據(jù)多個(gè)列創(chuàng)建索引; 例如你可以有基于三個(gè)列創(chuàng)建一個(gè)多列索引索引INDEX(col1, col2, col3), 那么可用的索引有INDEX(col1), INDEX(col1, col2)以及INDEX(col1, col2, col3)雕崩。^[4]

以下查詢是會(huì)使用索引:

SELECT * FROM tbl_name WHERE col1=val1;
SELECT * FROM tbl_name WHERE col1=val1 AND col2=val2;
SELECT * FROM tbl_name WHERE col1=val1 AND col2=val2 AND col3=val3;

以下查詢則不會(huì)使用索引

SELECT * FROM tbl_name WHERE col2=val2;
SELECT * FROM tbl_name WHERE col2=val2 AND col3=val3;

4. 使用最優(yōu)索引

當(dāng)表存在多個(gè)索引, MySQL只會(huì)選擇MYSQL QUERY Optimizer認(rèn)為最有的一個(gè)索引進(jìn)行查詢而放棄其他索引, 絕大多數(shù)情況下MySQL都可以自動(dòng)選擇到最優(yōu)的索引。

索引選擇策略:^([2])

  • WHRER之后的字段會(huì)被納入索引候選名單;
  • 存在多個(gè)索引時(shí), 優(yōu)先使用蓋索引鍵值最短的索引;
  • 存在多列索引時(shí), 會(huì)使用任何最左前綴匹配的索引用于查詢;
  • 根據(jù)INDEX HINT優(yōu)先/強(qiáng)制使用某些索引^([5])融撞。

總結(jié)

  1. 以下情況可考慮是否索引存在問(wèn)題:

    • IOPS居高不下
    • CPU利用率居高不下
    • SQL執(zhí)行緩慢
  2. 定期觀察SQL執(zhí)行情況, 如果有執(zhí)行時(shí)間過(guò)長(zhǎng)的SQL, 應(yīng)該EXPLAIN^([6])看看是否存在全表掃描或者過(guò)半記錄掃描盼铁。

  3. 如果MYSQL QUERY Optimizer沒(méi)有選擇最優(yōu)的索引, 則通過(guò)INDEX HINT主動(dòng)指定當(dāng)前SQL使用的索引。

附錄

[1] 理解MySQL - 索引與優(yōu)化
http://www.cnblogs.com/hustcat/archive/2009/10/28/1591648.html
[2] How MySQL Uses Indexes
https://dev.mysql.com/doc/refman/5.6/en/mysql-indexes.html
[3] InnoDB FULLTEXT Indexes
https://dev.mysql.com/doc/refman/5.6/en/innodb-fulltext-index.html
[4] Multiple-Column Indexes
https://dev.mysql.com/doc/refman/5.6/en/multiple-column-indexes.html
[5] Index Hints
https://dev.mysql.com/doc/refman/5.6/en/index-hints.html
[6] Optimizing Queries with EXPLAIN
https://dev.mysql.com/doc/refman/5.6/en/using-explain.html
[7] MySQL 索引選擇原則
http://blog.chinaunix.net/uid-26896862-id-3328675.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末尝偎,一起剝皮案震驚了整個(gè)濱河市饶火,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌致扯,老刑警劉巖肤寝,帶你破解...
    沈念sama閱讀 217,084評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異急前,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)瀑构,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,623評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門裆针,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人寺晌,你說(shuō)我怎么就攤上這事世吨。” “怎么了呻征?”我有些...
    開(kāi)封第一講書人閱讀 163,450評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵耘婚,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我陆赋,道長(zhǎng)沐祷,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,322評(píng)論 1 293
  • 正文 為了忘掉前任攒岛,我火速辦了婚禮赖临,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘灾锯。我一直安慰自己兢榨,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,370評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布顺饮。 她就那樣靜靜地躺著吵聪,像睡著了一般。 火紅的嫁衣襯著肌膚如雪兼雄。 梳的紋絲不亂的頭發(fā)上吟逝,一...
    開(kāi)封第一講書人閱讀 51,274評(píng)論 1 300
  • 那天,我揣著相機(jī)與錄音赦肋,去河邊找鬼澎办。 笑死嘲碱,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的局蚀。 我是一名探鬼主播麦锯,決...
    沈念sama閱讀 40,126評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼琅绅!你這毒婦竟也來(lái)了扶欣?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 38,980評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤千扶,失蹤者是張志新(化名)和其女友劉穎料祠,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體澎羞,經(jīng)...
    沈念sama閱讀 45,414評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡髓绽,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,599評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了妆绞。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片顺呕。...
    茶點(diǎn)故事閱讀 39,773評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖括饶,靈堂內(nèi)的尸體忽然破棺而出株茶,到底是詐尸還是另有隱情,我是刑警寧澤图焰,帶...
    沈念sama閱讀 35,470評(píng)論 5 344
  • 正文 年R本政府宣布启盛,位于F島的核電站,受9級(jí)特大地震影響技羔,放射性物質(zhì)發(fā)生泄漏僵闯。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,080評(píng)論 3 327
  • 文/蒙蒙 一藤滥、第九天 我趴在偏房一處隱蔽的房頂上張望棍厂。 院中可真熱鬧,春花似錦超陆、人聲如沸牺弹。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,713評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)张漂。三九已至,卻和暖如春谨娜,著一層夾襖步出監(jiān)牢的瞬間航攒,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,852評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工趴梢, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留漠畜,地道東北人币他。 一個(gè)月前我還...
    沈念sama閱讀 47,865評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像憔狞,于是被迫代替她去往敵國(guó)和親蝴悉。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,689評(píng)論 2 354

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