91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何進行MySQL優化WHERE子句

發布時間:2021-11-17 09:24:51 來源:億速云 閱讀:230 作者:柒染 欄目:MySQL數據庫

今天就跟大家聊聊有關如何進行MySQL優化WHERE子句,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

MySQL優化WHERE子句

where優化主要是在SELECT中,因為他們最主要是在那里使用,但是同樣的優化也可被用于DELETE和UPDATE語句。
但請注意,下面的優化并不是完全的。MYSQL實施了許多優化,但我沒時間全部測試.

MySQL的一些優化列在下面:

刪除不必要的括號:
((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)

常數調入:
(a -> b>5 AND b=c AND a=5

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

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

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

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

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

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;

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

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優化WHERE子句有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

共和县| 虞城县| 深州市| 黎川县| 郯城县| 阿拉善盟| 调兵山市| 惠水县| 武宁县| 陇南市| 龙门县| 延长县| 海城市| 嘉鱼县| 桂林市| 文山县| 斗六市| 社会| 彩票| 台中县| 广河县| 财经| 久治县| 云林县| 三原县| 伽师县| 彝良县| 边坝县| 平远县| 抚远县| 嘉义县| 登封市| 阿尔山市| 大英县| 古丈县| 垣曲县| 凤庆县| 凌源市| 灌云县| 尼木县| 延边|