成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

MySQL:聯(lián)合索引與Where子句的優(yōu)化

數(shù)據(jù)庫(kù) MySQL 數(shù)據(jù)庫(kù)運(yùn)維
經(jīng)過(guò)實(shí)踐發(fā)現(xiàn),不要以為WHERE中的字段順序無(wú)所謂,可以隨便放在哪,應(yīng)該盡可能地第一次就過(guò)濾掉大部分無(wú)用的數(shù)據(jù),只返回最小范圍的數(shù)據(jù)。

本網(wǎng)站系統(tǒng)上線(xiàn)至今,數(shù)據(jù)量已經(jīng)不知不覺(jué)上到500M,近8W記錄了。涉及數(shù)據(jù)庫(kù)操作的基本都是變得很慢了,用的人都會(huì)覺(jué)得躁火~~然后把這個(gè)情況在群里一貼,包括機(jī)器配置什么的一說(shuō),馬上就有群友發(fā)話(huà)了,而且?guī)臀掖_定了不是機(jī)器配置的問(wèn)題,“深圳-槍手”熱心人他的機(jī)器512內(nèi)存過(guò)百W的數(shù)據(jù)里也跑得飛快,甚至跟那些幾W塊的機(jī)器一樣牛(吹過(guò)頭了),呵呵~~~

在群友的分析指點(diǎn)下,嘗試把排序、條件等一個(gè)一個(gè)去除來(lái)做測(cè)試,結(jié)果發(fā)現(xiàn)問(wèn)題就出在排序部分,去除排序的時(shí)候,執(zhí)行時(shí)間由原來(lái)的48秒變成0.3x秒,這是個(gè)什么檔次的變化呀~~看著這個(gè)結(jié)果我激動(dòng)ing.....

于是我把涉及排序的字段組成一個(gè)聯(lián)合索引alter table xx add index indexname(x1,x2,x3),經(jīng)過(guò)2分鐘創(chuàng)建新索引之后再執(zhí)行同一個(gè)SQL語(yǔ)句,哇塞0.28S。。。。爽

于是按照同樣的思路把其它幾個(gè)常用的SQL作了過(guò)些優(yōu)化,效果馬上見(jiàn)效

過(guò)了30分鐘再查slow sql記錄文件,不好了,發(fā)現(xiàn)原來(lái)一個(gè)好好的SQL變得灰常慢了,神馬情況?

幾經(jīng)分析和測(cè)試原來(lái)就是因?yàn)樘砑恿寺?lián)合索引的原因,而且這個(gè)SQL語(yǔ)句當(dāng)中有個(gè)or,當(dāng)把這個(gè)or改用union之后問(wèn)題排除。

這回又得出一個(gè)心得:寫(xiě)SQL的時(shí)候千萬(wàn)別一時(shí)就手,隨便寫(xiě)個(gè)就OK,那會(huì)為以為帶來(lái)很?chē)?yán)重的后果。

再附上一段關(guān)于Where子句的執(zhí)行順序:

在用MySQL查詢(xún)數(shù)據(jù)庫(kù)的時(shí)候,連接了很多個(gè)用,發(fā)現(xiàn)非常慢。例如:

  1. SELECT ... WHERE p.languages_id = 1 AND m.languages_id = 1 AND c.languages_id = 1 AND t.languages_id = 1 AND p.products_id IN (472,474) 

這樣查詢(xún)需要20多秒,雖然在各個(gè)字段上都建立了索引。用分析Explain SQL一分析,發(fā)現(xiàn)在***次分析過(guò)程中就返回了幾萬(wàn)條數(shù)據(jù):

WHERE p.languages_id = 1 ,然后再依次根據(jù)條件,縮小范圍。

而我改變一下WHERE 字段的位置之后,速度就有了明顯地提高:

  1. WHERE p.products_id IN (472,474) AND 
  2. p.languages_id = 1 AND m.languages_id = 1 AND c.languages_id = 1 AND t.languages_id = 1 

這樣,***次的條件是p.products_id IN (472,474),它返回的結(jié)果只有不到10條,接下來(lái)還要根據(jù)其它的條件來(lái)過(guò)濾,自然在速度上有了較大的提升。

經(jīng)過(guò)實(shí)踐發(fā)現(xiàn),不要以為WHERE中的字段順序無(wú)所謂,可以隨便放在哪,應(yīng)該盡可能地***次就過(guò)濾掉大部分無(wú)用的數(shù)據(jù),只返回最小范圍的數(shù)據(jù)。

希望能幫到有同樣遭遇的朋友。

 

【編輯推薦】

  1. MySQL中創(chuàng)建及優(yōu)化索引組織結(jié)構(gòu)的思路
  2. 微博 請(qǐng)問(wèn)你是怎么優(yōu)化數(shù)據(jù)庫(kù)的?
  3. MySQL技巧:結(jié)合相關(guān)參數(shù) 做好Limit優(yōu)化
  4. MySQL數(shù)據(jù)庫(kù)的優(yōu)化(下)MySQL數(shù)據(jù)庫(kù)的高可用架構(gòu)方案
  5. MySQL數(shù)據(jù)庫(kù)的優(yōu)化(上)單機(jī)MySQL數(shù)據(jù)庫(kù)的優(yōu)化
責(zé)任編輯:艾婧 來(lái)源: 5ishare.com
相關(guān)推薦

2010-09-26 09:50:36

SQL Where子句

2010-09-26 14:46:19

SQL WHERE子句

2009-09-10 17:30:15

LINQ Where子

2009-11-19 14:59:25

Oracle Wher

2017-07-25 12:07:14

MySQL索引SQL

2021-07-26 18:23:23

SQL策略優(yōu)化

2024-10-09 23:32:50

2024-09-19 08:09:37

MySQL索引數(shù)據(jù)庫(kù)

2020-10-19 19:45:58

MySQL數(shù)據(jù)庫(kù)優(yōu)化

2010-06-04 11:28:05

MySQL數(shù)據(jù)庫(kù)

2018-06-07 08:54:01

MySQL性能優(yōu)化索引

2024-02-27 09:12:24

PostgreSQL數(shù)據(jù)庫(kù)查詢(xún)WHERE 子句

2010-05-12 11:14:25

MySQL SQL優(yōu)化

2011-07-28 16:16:27

MySQL數(shù)據(jù)庫(kù)索引ORDER BY

2018-04-09 14:25:06

數(shù)據(jù)庫(kù)MySQL索引

2010-10-12 16:44:36

MySQL語(yǔ)句

2023-11-07 07:50:55

LIMIT子句下推優(yōu)化

2023-10-23 09:19:47

PawSQL數(shù)據(jù)庫(kù)

2024-04-17 12:58:15

MySQL索引數(shù)據(jù)庫(kù)

2018-01-23 10:29:50

主搜索店鋪搜索
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 亚洲一区二区在线播放 | 欧洲精品久久久久毛片完整版 | 日本公妇乱淫xxxⅹ 国产在线不卡 | 中文在线播放 | 国产欧美日韩在线观看 | 日日操夜夜操天天操 | 91在线观看| 欧美一区二区三区在线 | 亚洲国产精品久久久久秋霞不卡 | 三级在线视频 | 精品欧美一区二区精品久久久 | 久久aⅴ乱码一区二区三区 亚洲欧美综合精品另类天天更新 | 亚洲国产一区在线 | 国产男女猛烈无遮掩视频免费网站 | 精品久久久久久亚洲精品 | 亚洲第一视频网 | 日韩免费一区二区 | 色五月激情五月 | 免费在线黄色av | 国产视频1区 | 国产精品久久久久aaaa樱花 | 操操网站 | 国产精品久久久久久久久免费丝袜 | 九色.com| 欧美成人免费 | 国产片淫级awww | 亚洲日本一区二区 | 中文在线播放 | 久久精品久久久久久 | 色婷婷av一区二区三区软件 | 日韩中文字幕一区二区 | 一区视频在线播放 | 2022精品国偷自产免费观看 | 夜夜骑首页 | 九九九国产 | 午夜专区 | 国产一区二区三区免费 | 成人免费视频久久 | 中文字幕视频在线观看 | 日韩第一页| 欧美在线视频免费 |