MySQL如何優(yōu)化WHERE子句

這篇文章主要為大家展示了“MySQL如何優(yōu)化WHERE子句”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“MySQL如何優(yōu)化WHERE子句”這篇文章吧。

成都創(chuàng)新互聯(lián)公司長(zhǎng)期為上千客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開(kāi)放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為福建企業(yè)提供專業(yè)的成都做網(wǎng)站、網(wǎng)站設(shè)計(jì)、外貿(mào)營(yíng)銷網(wǎng)站建設(shè),福建網(wǎng)站改版等技術(shù)服務(wù)。擁有10年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開(kāi)發(fā)。

MySQL怎樣優(yōu)化WHERE子句(轉(zhuǎn))[@more@]where優(yōu)化主要是在SELECT中,因?yàn)樗麄冏钪饕窃谀抢锸褂?,但是同樣的?yōu)化也可被用于DELETE和UPDATE語(yǔ)句。

但請(qǐng)注意,下面的優(yōu)化并不是完全的。MYSQL實(shí)施了許多優(yōu)化,但我沒(méi)時(shí)間全部測(cè)試.

MySQL的一些優(yōu)化列在下面:

刪除不必要的括號(hào):
((a AND b) AND c OR (((a AND b) AND (c AND d))))
-> (a AND b AND c) OR (a AND b AND c AND d)

常數(shù)調(diào)入:
(a
-> b>5 AND b=c AND a=5

刪除常數(shù)條件:
(B>=5 AND B=5) OR (B=6 AND 5=5) OR (B=7 AND 5=6)
-> B=5 OR B=6

索引使用的常數(shù)表達(dá)式僅計(jì)算一次。
在一個(gè)單個(gè)表上的沒(méi)有一個(gè)WHERE的COUNT(*)直接從表中檢索信息。當(dāng)僅使用一個(gè)表時(shí),對(duì)任何NOT NULL表達(dá)式也這樣做。
無(wú)效常數(shù)表達(dá)式的早期檢測(cè)。MySQL快速檢測(cè)某些SELECT語(yǔ)句是不可能的并且不返回行。
如果你不使用GROUP BY或分組函數(shù)(COUNT()、MIN()……),HAVING與WHERE合并。
為每個(gè)子聯(lián)結(jié)(sub join),構(gòu)造一個(gè)更簡(jiǎn)單的WHERE以得到一個(gè)更快的WHERE計(jì)算并且也盡快跳過(guò)記錄。
所有常數(shù)的表在查詢中的在其他任何表之前被讀出。
一個(gè)常數(shù)的表是:
一個(gè)空表或一個(gè)有1行的表。
與在一個(gè)UNIQUE索引、或一個(gè)PRIMARY KEY的WHERE子句一起使用的表,這里所有的索引部分使用一個(gè)常數(shù)表達(dá)式并且索引部分被定義為NOT NULL。
所有下列的表用作常數(shù)表:

mysql> SELECT * FROM t WHERE primary_key=1;
mysql> SELECT * FROM t1,t2 WHERE t1.primary_key=1 AND t2.primary_key=t1.id;

對(duì)聯(lián)結(jié)表的最好聯(lián)結(jié)組合是通過(guò)嘗試所有可能性來(lái)找到:(。如果所有在ORDER BY和GROUP BY的列來(lái)自同一個(gè)表,那么當(dāng)聯(lián)結(jié)時(shí),該表首先被選中。
如果你使用SQL_SMALL_RESULT,MySQL將使用一個(gè)在內(nèi)存中的表。
如果有一個(gè)ORDER BY子句和一個(gè)不同的GROUP BY子句,或如果ORDER BY或GROUP BY包含不是來(lái)自聯(lián)結(jié)隊(duì)列中的第一個(gè)表的其他表的列,創(chuàng)建一個(gè)臨時(shí)表。
因?yàn)镈ISTINCT被變換到在所有的列上的一個(gè)GROUP BY,DISTINCT與ORDER BY結(jié)合也將在許多情況下需要一張臨時(shí)表。
每個(gè)表的索引被查詢并且使用跨越少于30% 的行的索引。如果這樣的索引沒(méi)能找到,將使用一個(gè)快速的表掃描。
在一些情況下,MySQL能從索引中讀出行,甚至不用查詢數(shù)據(jù)文件。如果索引使用的所有列是數(shù)字的,那么只有索引樹(shù)被用來(lái)解答查詢。
在每個(gè)記錄被輸出前,那些不匹配HAVING子句的行將被跳過(guò)。

下面是一些快速的查詢例子:

mysql> SELECT COUNT(*) FROM tbl_name;
mysql> SELECT MIN(key_part1),MAX(key_part1) FROM tbl_name;
mysql> SELECT MAX(key_part2) FROM tbl_name
WHERE key_part_1=constant;
mysql> SELECT ... FROM tbl_name
ORDER BY key_part1,key_part2,... LIMIT 10;
mysql> SELECT ... FROM tbl_name
ORDER BY key_part1 DESC,key_part2 DESC,... LIMIT 10;

下列查詢僅使用索引樹(shù)就可解決(假設(shè)索引列是數(shù)字的):

mysql> SELECT key_part1,key_part2 FROM tbl_name WHERE key_part1=val;
mysql> SELECT COUNT(*) FROM tbl_name
WHERE key_part1=val1 AND key_part2=val2;
mysql> SELECT key_part2 FROM tbl_name GROUP BY key_part1;

下列查詢使用索引以排序順序檢索,不用一次另外的排序:

mysql> SELECT ... FROM tbl_name ORDER BY key_part1,key_part2,...
mysql> SELECT ... FROM tbl_name ORDER BY key_part1 DESC,key_part2 DESC,...

以上是“MySQL如何優(yōu)化WHERE子句”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

網(wǎng)站標(biāo)題:MySQL如何優(yōu)化WHERE子句
鏈接分享:http://bm7419.com/article40/pceeho.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)建站網(wǎng)站改版、企業(yè)網(wǎng)站制作、網(wǎng)站營(yíng)銷、小程序開(kāi)發(fā)、網(wǎng)站收錄

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都app開(kāi)發(fā)公司