亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL查詢性能優(yōu)化七種方式索引潛水

 更新時(shí)間:2022年08月05日 08:41:44   作者:一燈架構(gòu)???????  
這篇文章主要介紹了MySQL查詢性能優(yōu)化七種方式索引潛水,文章為榮啊主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下

前言:

有讀者可能會一臉懵?

啥是索引潛水?

你給起的名字的嗎?有沒有索引蛙泳?

這個(gè)名字還真不是我起的,今天要講的知識點(diǎn)就叫索引潛水(Index dive) 。

先要從一件怪事說起:

我先造點(diǎn)數(shù)據(jù)復(fù)現(xiàn)一下問題,創(chuàng)建一張用戶表:

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執(zhí)行計(jì)劃:

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

where條件中有9個(gè)參數(shù),重點(diǎn)關(guān)注一下執(zhí)行計(jì)劃中的預(yù)估掃描行數(shù)為279行。

到這里沒什么問題,預(yù)估的非常準(zhǔn),實(shí)際就是279行。

但是,問題來了,當(dāng)我們在where條件中,再加一個(gè)參數(shù),變成了10個(gè)參數(shù),預(yù)估掃描行數(shù)本應(yīng)該增加,結(jié)果卻大大減少了。

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

一下子減少到了30行,可是實(shí)際行數(shù)是多少呢?

實(shí)際是310行,預(yù)估掃描行數(shù)是30行,真是錯到姥姥家了。

MySQL咋回事啊,到底還能不能預(yù)估?

不能預(yù)估的話,換其他人!

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

跟這個(gè)詞語相關(guān)的,還有一個(gè)配置參數(shù) eq_range_index_dive_limit

MySQL5.7.3之前的版本,這個(gè)值默認(rèn)是10,之后的版本,這個(gè)值默認(rèn)是200。

可以使用命令查看一下這個(gè)值的大?。?/strong>

show variables like '%eq_range_index_dive_limit%';

當(dāng)然,我們也可以手動修改這個(gè)值的大小:

set eq_range_index_dive_limit=200;

這個(gè) eq_range_index_dive_limit 配置的作用就是:

當(dāng)where語句in條件中參數(shù)個(gè)數(shù)小于這個(gè)值的時(shí)候,MySQL就采用索引潛水(Index dive) 的方式預(yù)估掃描行數(shù),非常準(zhǔn)確。

當(dāng)where語句in條件中參數(shù)個(gè)數(shù)大于等于這個(gè)值的時(shí)候,MySQL就采用另一種方式索引統(tǒng)計(jì)(Index statistics) 預(yù)估掃描行數(shù),誤差較大。

MySQL為什么要這么做呢?

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

其實(shí)這是基于成本的考慮,索引潛水估算成本較高,適合小數(shù)據(jù)量。索引統(tǒng)計(jì)估算成本較低,適合大數(shù)據(jù)量。

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

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

如果你們項(xiàng)目中in條件最多有500個(gè)參數(shù),就把配置參數(shù)改成501。

這樣MySQL預(yù)估掃描行數(shù)更準(zhǔn)確,可以選擇更合適的索引。

到此這篇關(guān)于MySQL查詢性能優(yōu)化七種方式索引潛水的文章就介紹到這了,更多相關(guān)MySQL查詢優(yōu)化內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mysql中格式化日期詳解

    mysql中格式化日期詳解

    最近因?yàn)楣ぷ餍枰?,要使用mysql查詢記錄可如果有時(shí)間戳字段時(shí),查看結(jié)果不方便,不能即時(shí)看到時(shí)間戳代表的含義,所以這篇文章就提供mysql格式換時(shí)間函數(shù),可以方便的看到格式化后的時(shí)間。有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-11-11
  • MySQL的match函數(shù)在sp中使用BUG解決分析

    MySQL的match函數(shù)在sp中使用BUG解決分析

    這篇文章主要為大家介紹了MySQL的match函數(shù)在sp中使用BUG解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • 不重啟Mysql修改root密碼的方法

    不重啟Mysql修改root密碼的方法

    如何不重啟mysqld,且沒有權(quán)限修改用戶賬號和權(quán)限的情況下,如何重新設(shè)置root密碼?不知道沒關(guān)系,在此之前我也是不知道如何操作的,先看看下面的幾種重置root密碼的方法
    2014-03-03
  • mysql解壓包的安裝基礎(chǔ)教程

    mysql解壓包的安裝基礎(chǔ)教程

    這篇文章主要為大家詳細(xì)介紹了mysql解壓包的安裝基礎(chǔ)教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • MySQL 5.7常見數(shù)據(jù)類型

    MySQL 5.7常見數(shù)據(jù)類型

    這篇文章主要介紹了MySQL 5.7數(shù)據(jù)類型詳解,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-07-07
  • mysql 常用命令用法總結(jié)腳本之家整理版

    mysql 常用命令用法總結(jié)腳本之家整理版

    在日常工作中,會簡單的使用一下mysql,故對常見命令操作總結(jié)一下,常用方式如下
    2010-02-02
  • MYSQL實(shí)現(xiàn)連續(xù)簽到功能斷簽一天從頭開始(sql語句)

    MYSQL實(shí)現(xiàn)連續(xù)簽到功能斷簽一天從頭開始(sql語句)

    這篇文章主要介紹了MYSQL實(shí)現(xiàn)連續(xù)簽到功能斷簽一天從頭開始,非常不錯,具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-05-05
  • 解決mysql與navicat建立連接出現(xiàn)1251錯誤

    解決mysql與navicat建立連接出現(xiàn)1251錯誤

    在本篇文章里小編給大家整理了一篇關(guān)于mysql與navicat建立連接出現(xiàn)1251錯誤怎么解決的技術(shù)文章,需要的朋友們參考下。
    2019-08-08
  • MySQL數(shù)據(jù)庫之存儲過程?procedure

    MySQL數(shù)據(jù)庫之存儲過程?procedure

    這篇文章主要介紹了MySQL數(shù)據(jù)庫之存儲過程?procedure,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下
    2022-06-06
  • mysql limit 分頁的用法及注意要點(diǎn)

    mysql limit 分頁的用法及注意要點(diǎn)

    limit在mysql語句中使用的頻率非常高,一般分頁查詢都會使用到limit語句,本文章向碼農(nóng)們介紹mysql limit 分頁的用法與注意事項(xiàng),需要的朋友可以參考下
    2016-12-12

最新評論