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

溫馨提示×

溫馨提示×

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

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

MySQL查詢性能優化的索引潛水實例分析

發布時間:2022-08-05 10:47:36 來源:億速云 閱讀:169 作者:iii 欄目:開發技術

這篇“MySQL查詢性能優化的索引潛水實例分析”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“MySQL查詢性能優化的索引潛水實例分析”文章吧。

先要從一件怪事說起:

我先造點數據復現一下問題,創建一張用戶表:

CREATE TABLE `user` (
  `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主鍵ID',
  `name` varchar(100) NOT NULL DEFAULT '' COMMENT '姓名',
  `age` int(11) NOT NULL DEFAULT 0 COMMENT '年齡',
  PRIMARY KEY (`id`),
  KEY `idx_age` (`age`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

通過一批用戶年齡,查詢該年齡的用戶信息,并查看一下SQL執行計劃:

explain select * from user 
where age in (1,2,3,4,5,6,7,8,9);

MySQL查詢性能優化的索引潛水實例分析

where條件中有9個參數,重點關注一下執行計劃中的預估掃描行數為279行。

到這里沒什么問題,預估的非常準,實際就是279行。

MySQL查詢性能優化的索引潛水實例分析

但是,問題來了,當我們在where條件中,再加一個參數,變成了10個參數,預估掃描行數本應該增加,結果卻大大減少了。

explain select * from user
where age in (1,2,3,4,5,6,7,8,9,10);

MySQL查詢性能優化的索引潛水實例分析

一下子減少到了30行,可是實際行數是多少呢?

MySQL查詢性能優化的索引潛水實例分析

實際是310行,預估掃描行數是30行,真是錯到姥姥家了。

MySQL咋回事啊,到底還能不能預估?

不能預估的話,換其他人!

大家肯定也是滿臉疑惑,直到我去官網上看到了一個詞語,索引潛水(Index dive) 。

跟這個詞語相關的,還有一個配置參數 eq_range_index_dive_limit

MySQL5.7.3之前的版本,這個值默認是10,之后的版本,這個值默認是200。

可以使用命令查看一下這個值的大小:

show variables like '%eq_range_index_dive_limit%';

MySQL查詢性能優化的索引潛水實例分析

當然,我們也可以手動修改這個值的大小:

set eq_range_index_dive_limit=200;

這個 eq_range_index_dive_limit 配置的作用就是:

當where語句in條件中參數個數小于這個值的時候,MySQL就采用索引潛水(Index dive) 的方式預估掃描行數,非常準確。

當where語句in條件中參數個數大于等于這個值的時候,MySQL就采用另一種方式索引統計(Index statistics) 預估掃描行數,誤差較大。

MySQL為什么要這么做呢?

都用索引潛水(Index dive) 的方式預估掃描行數,不好嗎?

其實這是基于成本的考慮,索引潛水估算成本較高,適合小數據量。索引統計估算成本較低,適合大數據量。

一般情況下,我們的where語句的in條件的參數不會太多,適合使用索引潛水預估掃描行數。

建議還在使用MySQL5.7.3之前版本的同學們,手動修改一下索引潛水的配置參數,改成合適的數值。

如果你們項目中in條件最多有500個參數,就把配置參數改成501。

這樣MySQL預估掃描行數更準確,可以選擇更合適的索引。

以上就是關于“MySQL查詢性能優化的索引潛水實例分析”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

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

AI

宜丰县| 合川市| 冷水江市| 浏阳市| 海原县| 潼关县| 南开区| 慈溪市| 玛曲县| 正阳县| 永州市| 论坛| 宽甸| 韩城市| 漳浦县| 和田县| 洛南县| 津市市| 宜丰县| 菏泽市| 邵阳县| 甘肃省| 靖宇县| 抚州市| 平原县| 建阳市| 七台河市| 东乌珠穆沁旗| 宁乡县| 濉溪县| 林西县| 镶黄旗| 大足县| 依兰县| 普兰县| 庆元县| 舟曲县| 安达市| 盐边县| 沿河| 潜山县|