最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

精確度分析MySQL數(shù)據(jù)庫中優(yōu)化WHERE子句_MySQL

來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-09 17:23:01
文檔

精確度分析MySQL數(shù)據(jù)庫中優(yōu)化WHERE子句_MySQL

精確度分析MySQL數(shù)據(jù)庫中優(yōu)化WHERE子句_MySQL:MySQL優(yōu)化 Where優(yōu)化主要是在SELECT中,因為他們最主要是在那里使用,但是同樣的優(yōu)化也可被用于DELETE和UPDATE語句。 MySQL的一些優(yōu)化列在下面: 刪除不必要的括號: ((a AND b) AND c OR (((a AND b) AND (c AND
推薦度:
導(dǎo)讀精確度分析MySQL數(shù)據(jù)庫中優(yōu)化WHERE子句_MySQL:MySQL優(yōu)化 Where優(yōu)化主要是在SELECT中,因為他們最主要是在那里使用,但是同樣的優(yōu)化也可被用于DELETE和UPDATE語句。 MySQL的一些優(yōu)化列在下面: 刪除不必要的括號: ((a AND b) AND c OR (((a AND b) AND (c AND

MySQL優(yōu)化

Where優(yōu)化主要是在SELECT中,因為他們最主要是在那里使用,但是同樣的優(yōu)化也可被用于DELETE和UPDATE語句。

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

刪除不必要的括號:

((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ù)表達式僅計算一次。

在一個單個表上的沒有一個WHERE的COUNT(*)直接從表中檢索信息。當(dāng)僅使用一個表時,對任何NOT NULL表達式也這樣做。

無效常數(shù)表達式的早期檢測。MySQL快速檢測某些SELECT語句是不可能的并且不返回行。

如果你不使用GROUP BY或分組函數(shù)(COUNT()、MIN()……),HAVING與WHERE合并。

為每個子聯(lián)結(jié)(sub join),構(gòu)造一個更簡單的WHERE以得到一個更快的WHERE計算并且也盡快跳過記錄。

所有常數(shù)的表在查詢中的在其他任何表之前被讀出。

一個常數(shù)的表是,一個空表或一個有1行的表。

與在一個UNIQUE索引、或一個PRIMARY KEY的WHERE子句一起使用的表,這里所有的索引部分使用一個常數(shù)表達式并且索引部分被定義為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;

對聯(lián)結(jié)表的最好聯(lián)結(jié)組合是通過嘗試所有可能性來找到。如果所有在ORDER BY和GROUP BY的列來自同一個表,那么當(dāng)聯(lián)結(jié)時,該表首先被選中。

如果你使用SQL_SMALL_RESULT,MySQL將使用一個在內(nèi)存中的表。

如果有一個ORDER BY子句和一個不同的GROUP BY子句,或如果ORDER BY或GROUP BY包含不是來自聯(lián)結(jié)隊列中的第一個表的其他表的列,創(chuàng)建一個臨時表。

因為DISTINCT被變換到在所有的列上的一個GROUP BY,DISTINCT與ORDER BY結(jié)合也將在許多情況下需要一張臨時表。

每個表的索引被查詢并且使用跨越少于30% 的行的索引。如果這樣的索引沒能找到,將使用一個快速的表掃描。

在一些情況下,MySQL能從索引中讀出行,甚至不用查詢數(shù)據(jù)文件。如果索引使用的所有列是數(shù)字的,那么只有索引樹被用來解答查詢。

在每個記錄被輸出前,那些不匹配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;

下列查詢僅使用索引樹就可解決(假設(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,...

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

精確度分析MySQL數(shù)據(jù)庫中優(yōu)化WHERE子句_MySQL

精確度分析MySQL數(shù)據(jù)庫中優(yōu)化WHERE子句_MySQL:MySQL優(yōu)化 Where優(yōu)化主要是在SELECT中,因為他們最主要是在那里使用,但是同樣的優(yōu)化也可被用于DELETE和UPDATE語句。 MySQL的一些優(yōu)化列在下面: 刪除不必要的括號: ((a AND b) AND c OR (((a AND b) AND (c AND
推薦度:
標(biāo)簽: 一個 and 精確
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top