<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        MySQL怎樣優化WHERE子句

        來源:懂視網 責編:小采 時間:2020-11-09 14:42:32
        文檔

        MySQL怎樣優化WHERE子句

        MySQL怎樣優化WHERE子句:where優化主要是在SELECT中,因為他們最主要是在那里使用,但是同樣的優化也可被用于DELETE和UPDATE語句。 但請注意,下面的優化并不是完全的。MYSQL實施了許多優化,但我沒時間全部測試. MySQL的一些優化列在下面: 刪除不必要的括號: ((a AND b)
        推薦度:
        導讀MySQL怎樣優化WHERE子句:where優化主要是在SELECT中,因為他們最主要是在那里使用,但是同樣的優化也可被用于DELETE和UPDATE語句。 但請注意,下面的優化并不是完全的。MYSQL實施了許多優化,但我沒時間全部測試. MySQL的一些優化列在下面: 刪除不必要的括號: ((a AND b)

        where優化主要是在SELECT中,因為他們最主要是在那里使用,但是同樣的優化也可被用于DELETE和UPDATE語句。 但請注意,下面的優化并不是完全的。MYSQL實施了許多優化,但我沒時間全部測試. MySQL的一些優化列在下面: 刪除不必要的括號: ((a AND b) AND c OR

        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,...

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

        文檔

        MySQL怎樣優化WHERE子句

        MySQL怎樣優化WHERE子句:where優化主要是在SELECT中,因為他們最主要是在那里使用,但是同樣的優化也可被用于DELETE和UPDATE語句。 但請注意,下面的優化并不是完全的。MYSQL實施了許多優化,但我沒時間全部測試. MySQL的一些優化列在下面: 刪除不必要的括號: ((a AND b)
        推薦度:
        標簽: 語句 怎樣 mysql
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top 主站蜘蛛池模板: 亚洲欧洲免费视频| 日产国产精品亚洲系列| 久久亚洲AV无码精品色午夜麻| 一级毛片人与动免费观看| 免费亚洲视频在线观看| 免费精品久久久久久中文字幕| 亚洲成年人啊啊aa在线观看| 香蕉97碰碰视频免费| 亚洲精品无码久久久久AV麻豆| 大片免费观看92在线视频线视频 | 暖暖免费中文在线日本| 亚洲M码 欧洲S码SSS222| 巨胸喷奶水视频www免费视频| 亚洲精品国产美女久久久| 无码国产精品一区二区免费模式| 亚洲一级二级三级不卡| 精品久久久久成人码免费动漫 | 免费a级毛片无码av| 久久国产精品免费一区| 亚洲国产成人片在线观看无码 | 毛片免费在线观看网址| 婷婷亚洲综合五月天小说在线| 亚洲&#228;v永久无码精品天堂久久 | 成人免费视频一区| 羞羞网站免费观看| 亚洲AV无码专区在线播放中文| 中文字幕无码播放免费| 国产亚洲Av综合人人澡精品| 三上悠亚亚洲一区高清| 亚洲三级高清免费| 爱情岛论坛免费视频| 久久国产精品亚洲一区二区| 成年女人午夜毛片免费视频 | 色多多A级毛片免费看| 亚洲国产精品lv| 国产美女无遮挡免费视频网站| a级男女仿爱免费视频| 欧洲 亚洲 国产图片综合| 亚洲午夜久久久影院伊人| 免费电影在线观看网站| 国产午夜精品理论片免费观看 |