日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

MySQL如何構建數據表索引

瀏覽:19日期:2023-10-03 09:30:52
目錄支持多種類型的過濾避免多個范圍查詢優化排序

理解索引概念最簡單的方式是通過一個案例來進行,以下就是這樣的一個案例。

假設我們需要設計一個在線的約會網站,這個網站的用戶資料有許多列,例如國籍、省份、城市、性別、年齡、眼睛顏色等等。這個網站必須支持通過多種組合方式搜索用戶資料。同時,也需要支持支持排序和根據用戶最近在線時間和其他用戶的評價返回有限的結果等等。對于這種復雜場景我們如何設計索引?

有點奇怪,首先要做的事情是要決定我們是否必須使用索引排序,或者檢索后再排序是否能夠接受。索引排序限制了索引和查詢構建的方式。例如,在WHERE age BETWEEN 18 AND 25這樣的查詢條件和基于其他用戶評價排序的場景中,我們不能使用同一個索引。如果MySQL在范圍查詢中使用了一個索引,那就沒法在排序中使用另一個索引。假設這是一個最常用的WHERE條件,同時我們還需要支持大多數查詢都可以排序。

支持多種類型的過濾

現在我們需要看看哪些列的值比較分散以及哪些列在WHERE條件中最常出現。數據列值比較分散的篩選性很好。這通常會是一個好事情,因為這讓MySQL可以將高效過濾掉不相關的數據行。

國籍列可能篩選性不太好,但卻可能是最常查詢的。性別列通常不具備篩選性,但卻也經常用于查詢。基于這樣的認識,我們為許多不同的列的組合創建了一系列的索引,這些索引使用(sex, country)開頭。

傳統的認知是對于低篩選性的列構建索引是沒用的。那我們為什么要在每個索引開頭都加上不具篩選性的列? 我們有兩個理由這么做。第一個理由是,如前所述,基本每個查詢都會使用性別。我們甚至設計了用戶一次只能搜索一個性別。但更重要的是,增加這樣的列并沒有多少缺點,因為我們使用了一個小招數。

這是我們的招數:即便不限制性別查詢,我們也能夠保證在WHERE語句中加上AND sex IN(’m’, ’f’)讓索引生效。這不會過濾掉我們所需要的行,因此與WHERE語句中不包含性別作用相同。然而,因為MySQL會在更多列的索引中前置這個列,我們需要包含這個列。這個招術在這樣的場景下有效,但是如果是這個列具有很多不同的值,那反而不起作用,這是因為這會導致IN()中的列過多。

這個例子闡述了一個基本的原則:在數據表設計上保留所有的選項。當你設計索引的時候,不要只想著那種查詢中的那類索引,也同時考慮優化查詢。當你需要一個索引卻發現其他查詢可能會受其影響,你應該先問問自己能否改變查詢。你應該同時優化查詢和索引去找到解決之道。你不一定需要設計完美的索引。

接下來,我們需要考慮可能用到的其他組合的WHERE條件,然后考慮其中的哪些組合在沒有合理索引的情況下會變慢。(sex, country, age)這樣的索引是很明顯的選擇,但我們也可能需要(sex, country, region, age)和(sex, country, region, city, age)這樣的索引。

這會導致需要建立很多的索引。如果我們能夠重復利用索引,那就不會產生過多的組合。我們可以使用IN()這種小招數來去掉(sex, country, age)和(sex, country, region, age)索引。如果這些列在搜索表單中沒有指定,我們可以使用國家清單、地區清單來保證滿足索引前置的約束(全部國家,全部地區和全部性別的組合可能很多)。

這些索引會滿足指定的大部分搜索查詢,但我們如何設計那些不那么常見的篩選,例如上傳了圖片(has_pictures),眼睛顏色(eye_color),頭發顏色(hair_color)和教育水平(education)?如果這些列不是那么具有篩選性并且不那么常用,我們可以直接跳過他們,讓MySQL去掃描額外的一些數據行。相應地,我們可以在age列前增加他們,并且使用IN()技巧去提前描述以處理那種這些列沒有指定的情況。

你也許注意到我們將age放到了索引的最后面。為什么要特別處理這個列?我們在試圖保證MySQL能夠盡可能多地利用索引列。由于MySQL使用最左匹配規則,直到遇到第一個范圍查詢條件。所有我們提到的列都可以在WHERE語句中使用相等條件,但年齡(age)大概率是范圍查詢。

我們也能夠將范圍查詢改為清單使用IN查詢,例如age IN(18, 19, 20, 21, 22, 23, 24, 25)來替代age BETWEEN 18 AND 25,但這并不總是能夠這么做。通用的原則是我們盡量將范圍判決條件放到索引的末尾,因此優化器會盡可能地使用索引。

我們提到你可以使用盡可能多的列使用IN查詢去覆蓋那些在WHERE條件中未指定的索引條件。但你可能做得過頭了導致新的問題。使用更多的這樣的IN查詢清單導致優化器需要評估大量的組合,這反而可能降低查詢速度。考慮下面的查詢條件語句:

WHERE eye_color IN(’brown’, ’blue’, ’hazel’)AND hair_colorIN(’black’, ’red’, ’blonde’, ’brown’) AND sex IN(’M’, ’F’)

這個優化器會轉變為432=24種組合,WHERE條件會檢查每一種情況。24還不是一個很大的組合數字,但如果數量達到了幾千。舊版本的MySQL在IN查詢中數量過多時可能會有更多的問題。查詢優化器會執行更慢并且消耗很多內存。新版本的MySQL會在組合過多時停止評估,但這會影響MySQL使用索引。

避免多個范圍查詢

讓我們假設有一個last_online(最近在線時間)的列,然后我們需要展示最近一周在線的用戶:

WHERE eye_colorIN(’brown’, ’blue’, ’hazel’)AND hair_colorIN(’black’, ’red’, ’blonde’, ’brown’) AND sex IN(’M’, ’F’) AND last_online > DATE_SUB(NOW(), INTERVAL 7 DAY) AND ageBETWEEN 18 AND 25

這個查詢的問題在于它有兩個范圍查詢。MySQL可以使用last_online或age條件,但不能同時使用。 如果last_online約束出現時沒有age約束,或last_online比age更有篩選性,我們可能希望增加另一組索引,將last_online放到最后面。但是如果我們不能將age轉換為IN查詢,而我們也希望能夠在同時有last_oinline和age范圍查詢時提高查詢速度怎么辦?這個時候,我們沒有直接的方法。但我們可以將一個范圍轉換為相等比較。去這么做的時候,我們增加一個預先計算的active列,這個列我們會定期維護。如果用戶登錄后,我們標記為1,如果7天內沒有連續登錄則重新標記為0。

這個方法可以讓MySQL使用如(active, sex, country, age)這樣的索引。這個列也許沒那么精準,但這類查詢也許不需要很高的精準度。如果我們需要精準查詢,我們可以保留last_online在WHERE條件中,但不增加索引。這種技巧與URL查找的情況類似。這種條件不會使用任何索引,因為它不太可能會將索引命中的行給過濾掉。增加索引未必能夠讓查詢收益。

現在,你可以看到這個模式:如果用戶想同時查找活躍和不活躍的結果,我們可以使用IN查詢。我們增加了很多這樣的清單查詢,一個變通的方式是通過將各個組合分開的查詢單獨建立索引,例如,我們可以使用如下的索引:(active, sex, country, age),(active, country, age),(sex, country, age)和(country, age)。雖然這樣的索引對于特定的查詢可能是更優的選擇,但維護這些組合的負面效果,組合所需的額外存儲空間都可能導致是一個很弱的策略。

這是一個優化器改變后可以真正影響索引優化的案例。如果在未來的MySQL版本中可以真正丟棄索引掃描,它可能能夠在一個索引上使用多個范圍條件,此時我們不再需要通過IN查詢這種方式解決此類問題。

優化排序

最后一個議題是排序。小數據量的結果使用文件排序(filesort)很快,但如果是上百萬行數據呢?例如,如果只在WHERE條件中指定了性別時的排序。

對于這類低篩選性的場景,我們可以增加特定的索引用于排序。例如,一個(sex, rating)的索引可以用于下面的查詢:

SELECT <cols> FROM profiles WHERE sex=’M’ ORDER BY rating LIMIT 10;

這個查詢同時有排序和LIMIT子句,在沒有索引的情況下可能很慢。即便是有索引,這個查詢在用戶界面有分頁查詢,而頁碼不在起始位置附近時也可能很慢。下面的例子的ORDER BY和LIMIT造成了一個糟糕的組合:

SELECT <cols> FROM profiles WHERE sex=’M’ ORDER BY rating LIMIT 100000, 10;

即便有索引,這樣的查詢也可能導致十分嚴重的問題。這是因為很高的偏移會導致花費大量的時間掃描大量的數據,且這些數據會被丟棄。反范式設計,提前計算和緩存可能能夠解決這類查詢的問題。一個更好的策略是限制用戶可查詢的頁碼。這不太可能會降低用戶的體驗,因為實際上不會有人會關心第10000頁的搜索結果。

另一個好的策略是使用推斷聯合查詢,這是我們利用覆蓋索引去獲取主鍵列后再獲取數據行的方式。你可以將需要獲取的列全部聯合,這會減少MySQL收集那些需要丟棄的數據的工作。下面是一個例子:

SELECT <cols> FROM profiles INNER JOIN ( SELECT <primary key cols> FROM profiles WHERE x.sex=’M’ ORDER BY rating LIMIT 100000, 10AS x USING(<primary key cols>);

以上就是MySQL如何構建數據表索引的詳細內容,更多關于MySQL構建數據表索引的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
午夜av一区| 美女91精品| 日本精品久久| 日韩福利在线观看| 欧美日韩视频免费看| 日本一区中文字幕| 国产日产精品_国产精品毛片 | 亚洲精品123区| 国产91精品对白在线播放| 99久久久国产精品美女| jiujiure精品视频播放| 视频一区视频二区中文字幕| 久久电影一区| 日本成人在线不卡视频| 国产午夜久久av| 精品久久在线| 日韩成人高清| 亚洲欧美成人综合| 在线精品国产亚洲| 欧美一区免费| 麻豆国产91在线播放| 国产91在线精品| 日韩精品一区二区三区免费观影| 欧美午夜精品一区二区三区电影| 午夜一级在线看亚洲| 国产亚洲一区二区三区啪| 欧美激情aⅴ一区二区三区 | 老鸭窝一区二区久久精品| 国产一区二区三区不卡视频网站| 国产一区二区三区四区大秀| 婷婷中文字幕一区| 国产日韩欧美一区在线| 日本精品在线中文字幕| 石原莉奈在线亚洲三区| 国产精品久久久久av蜜臀| 午夜av成人| 亚洲精品精选| 欧美日韩免费看片| 亚洲精选成人| 日韩久久精品| 日韩精品欧美大片| 丝袜美腿诱惑一区二区三区 | 亚洲久久一区| 国产91在线精品| 综合国产精品| 亚洲天堂一区二区| 国产区精品区| 久久xxxx精品视频| 福利精品一区| 亚洲日本免费电影| 中文字幕高清在线播放| 亚洲精品影视| 国产尤物精品| 麻豆一区二区99久久久久| 亚洲中字黄色| 在线中文字幕播放| 欧美久久亚洲| 激情久久久久久| 久久精品免视看国产成人| 亚洲另类黄色| 蜜臀av免费一区二区三区| 精品一区91| 日韩av资源网| 日韩在线一区二区| 久久久久午夜电影| 久久亚洲黄色| 国产日韩欧美在线播放不卡| 不卡在线一区二区| 国产一区二区三区日韩精品| 亚洲综合福利| 日韩一级精品| 欧美gv在线| 国产色噜噜噜91在线精品| 日韩中文字幕亚洲一区二区va在线| 神马久久午夜| 美女国产一区二区三区| 91精品视频一区二区| 视频在线在亚洲| 欧美特黄一区| 久久视频国产| 电影亚洲精品噜噜在线观看| 久久91视频| 国产精品久久久久久妇女| 亚洲三级视频| 免费观看日韩电影| 性色一区二区| 丝袜美腿亚洲色图| 欧美肉体xxxx裸体137大胆| 亚洲风情在线资源| 日本不良网站在线观看| 精品国产亚洲一区二区三区在线| 国产三级精品三级在线观看国产| 最近国产精品视频| 亚洲精品日韩久久| 日韩精品亚洲专区| 久久国产日韩欧美精品| 国产日产一区| 国产 日韩 欧美 综合 一区| 精品国产第一福利网站| 91看片一区| 黄色成人91| 亚洲一级大片| 亚洲精品一级二级三级| 91成人在线网站| 国产精品v亚洲精品v日韩精品| 久久一区精品| 成人午夜国产| av高清不卡| 中文在线免费视频| 国产欧美日韩在线一区二区| 久久精品国内一区二区三区水蜜桃| 亚洲无线观看| 久久精品中文| 成人一区而且| 美女视频黄久久| 婷婷综合电影| 午夜欧美精品久久久久久久| 一本综合精品| 亚洲国产专区| 伊人久久大香线蕉av不卡| 久久激情婷婷| 日本在线成人| 亚洲精品观看| 中文字幕日韩亚洲| 六月丁香综合| 亚洲日产av中文字幕| 视频一区二区三区入口| 午夜在线精品| 久久婷婷av| 久久最新视频| 久久精品国产99久久| 欧美一区二区性| 国产欧美日韩精品高清二区综合区| 日本欧美久久久久免费播放网| 日韩国产在线观看| 国产日本精品| 国产精品久久久久蜜臀| 国产亚洲字幕| 久久久久久一区二区| 人人精品亚洲| 国产一级一区二区| | 亚洲精品国产日韩| 欧美精品影院| 日韩av有码| 日韩在线精品| 精品国模一区二区三区| 亚洲性色视频| 美国欧美日韩国产在线播放| 91精品国产自产精品男人的天堂| 国产精品a级| av一区在线| 日韩av一二三| 国产不卡av一区二区| 亚洲大全视频| 无码日韩精品一区二区免费| 久久不见久久见中文字幕免费| 福利在线免费视频| 中文字幕一区二区三区四区久久| 国产欧美日韩亚洲一区二区三区| 国产精品蜜芽在线观看| 米奇777超碰欧美日韩亚洲| 日韩中文字幕在线一区| 精品视频91| 亚洲主播在线| 国产精品极品国产中出| 精品久久久久中文字幕小说| 激情黄产视频在线免费观看| 日韩亚洲精品在线| 国产精品密蕾丝视频下载| 在线观看精品| 亚洲精品极品| а√在线中文在线新版| 亚洲综合激情在线| 国产精品国产一区| 午夜在线一区| 电影91久久久| 综合亚洲视频| 日本欧美不卡| 精品三级在线观看视频| 久久成人国产| 亚洲最新无码中文字幕久久| 亚洲制服欧美另类| 国产成人精品亚洲日本在线观看| 久久激情婷婷| 成人在线黄色| 亚洲精品一级| 五月天久久777| 精品一区91| 免费的成人av| 欧美日韩一区二区国产| 亚洲性视频h| 精品久久中文| 日韩福利视频一区| 亚洲国产日韩欧美在线| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 亚洲欧洲另类| 精精国产xxxx视频在线播放| 国产日韩欧美一区二区三区 | 久久不射网站|