精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Explain 顯示 Count(*) 使用了索引,實際卻是全表掃描

數據庫 MySQL
從 8.0.17(含)版本開始,直到目前的最新版本(8.0.33),如果表中有二級索引,explain 輸出的執行計劃也表示會使用二級索引,然而,實際執行過程中,InnoDB 卻會強制進行全表掃描,以使用主鍵索引的并行掃描能力。

這篇文章依然源于一位讀者的提問:explain 顯示 count(*) 使用了索引,optimizer trace 卻顯示為全表掃描,這是為什么?

還記得當時調試源碼的過程中,如果 explain 顯示會使用二級索引進行全索引掃描,執行時也確實只會從二級索引中讀取記錄,不會進行全表掃描。

不過,那會沒有關注過 optimizer trace 是怎么顯示的。

既然不能從記憶里找到答案,那就只能從源碼里找答案了。

擼完源碼發現:和 5.7.35 版本相比,8.0.32 的 count(*) 實現邏輯,確實有了一些變化。

接下來,我們一起來看看。

本文基于 MySQL 8.0.32 源碼,存儲引擎為 InnoDB。如需轉載,請聯系『一樹一溪』公眾號作者。

1、準備工作

創建測試表:

CREATE TABLE `t1` (
  `id` int unsigned NOT NULL AUTO_INCREMENT,
  `i1` int DEFAULT '0',
  PRIMARY KEY (`id`) USING BTREE,
  KEY `idx_i1` (`i1`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3

插入數據:

INSERT INTO `t1`(`id`, `i1`)
VALUES (10, 101), (20, 201), (30, 301);

2、問題重現及分析

explain 查看執行計劃:

EXPLAIN SELECT COUNT(*) FROM `t1`;

結果如下(只截取了部分字段):

圖片圖片

再來看看 optimizer trace 描述的執行計劃,依次執行以下 3 條 SQL:

-- 開啟 optimizer trace
SET optimizer_trace = "enabled=on";

-- 執行 SELECT 語句
SELECT COUNT(*) FROM `t1`;

-- 獲取 optimizer trace
SELECT * FROM information_schema.optimizer_trace;

結果如下(只截取了部分內容):

{
  "considered_execution_plans": [
    {
      "plan_prefix": [
      ],
      "table": "`t1`",
      "best_access_path": {
        "considered_access_paths": [
          {
            "rows_to_scan": 3,
            "access_type": "scan",
            "resulting_rows": 3,
            "cost": 0.55,
            "chosen": true
          }
        ]
      },
      "condition_filtering_pct": 100,
      "rows_for_plan": 3,
      "cost_for_plan": 0.55,
      "chosen": true
    }
  ]
}

我們來對比下 explain 和 optimizer trace 的結果:

  • explain 輸出結果中,type 字段值為 index、key 字段值為 idx_i1,表示會使用 idx_i1 作為覆蓋索引執行 select 語句。由于沒有 where 條件,select 語句會對二級索引 idx_i1 進行全索引掃描,以獲取 t1 表的記錄數量。
  • optimizer trace 輸出結果中,沒有顯示會使用索引 idx_i1,而且,access_type 為 scan,看起來像是會進行全表掃描。

我在 5.7.35 中調試了這條 SQL:

SELECT COUNT(*) FROM `t1`

可以證實,select 語句執行過程中,確實對 idx_i1 進行了全索引掃描,和 explain 輸出的執行計劃一致。

同時也確認了:不管是對主鍵索引進行全索引掃描(也就是全表掃描),還是對二級索引進行全索引掃描,optimizer trace 的輸出結果中,access_type 字段值都是 scan。

我又在 8.0.32 中調試了上面的 SQL,發現了新情況:InnoDB 對不包含 where 條件的 select count(*) from table 語句進行了特殊處理。

跟隨調試過程,我們一起來看看 InnoDB 做了什么特殊處理。

程序執行到 ha_records() 方法時,我們可以看到,index 參數的值是 1,這就是執行計劃確定要使用的索引 ID。

圖片圖片

我們在調試控制臺打印索引名字,可以看到 ID = 1 的索引就 idx_i1:

圖片圖片

ha_records() 會調用 records_from_index(),代碼如下:

圖片圖片

從以上代碼可以看到,ha_records() 把索引 idx_i1 的 ID 傳給了 records_from_index() 的第 2 個參數,但是,該方法的第 2 個參數,只有類型(uint),沒有名字,這說明第 2 個參數不能被使用。

也就是說,雖然執行計劃確定了要使用索引 idx_i1 來統計 t1 表的記錄數量,records_from_index() 卻沒有真正使用 idx_i1。

從代碼注釋也可以看到:在實現二級索引的并行掃描之前,records_from_index() 會強制使用主鍵索引來統計表中的記錄數量。

在 github 中追溯代碼提交歷史,發現 records_from_index() 是 8.0.17 版本新加的。

從這個版本開始,到最新的 8.0.33,對于不包含 where 條件的 select count(*) from table 語句,都會強制使用主鍵索引(也就是會進行全表掃描)。

之所以這么做,是為了使用多個線程對主鍵索引進行并行掃描,以提升執行速度。

3、總結

雖然本文內容比較短,但是本著完整的原則,還是進行個簡單的總結:

  • 8.0.16(含)版本之前,對于 select count(*) from table 語句,如果表中有二級索引,InnoDB 會選擇對某個二級索引進行全索引掃描,以獲取表中的記錄數量。
  • 從 8.0.17(含)版本開始,直到目前的最新版本(8.0.33),如果表中有二級索引,explain 輸出的執行計劃也表示會使用二級索引,然而,實際執行過程中,InnoDB 卻會強制進行全表掃描,以使用主鍵索引的并行掃描能力。
  • optimizer trace 的結果中,對于 select count(*) from table 語句,二級索引的全索引掃描和全表掃描同等對待,執行計劃的 access_type 字段值都是 scan。
責任編輯:姜華 來源: 一樹一溪
相關推薦

2025-11-06 01:21:00

2010-04-27 17:02:18

Oracle EXPL

2022-12-05 08:35:06

MySQL計算讀取

2010-05-19 10:37:06

MySQL expla

2017-09-05 12:44:15

MySQLSQL優化覆蓋索引

2024-10-28 08:34:06

2011-08-24 17:23:10

2023-02-26 01:00:12

索引優化慢查詢

2011-08-24 15:11:15

explain中文man

2010-04-28 17:14:38

Oracle EXPL

2018-04-04 12:05:04

Postgre數據planner

2020-08-10 11:20:59

索引MySQL數據庫

2010-04-14 16:45:29

Oracle 9i全索

2009-11-10 17:27:01

Oracle全表掃描

2009-11-11 09:40:53

Oracle索引掃描

2010-04-14 16:22:42

Oracle 9i

2019-07-29 09:42:56

索引死鎖MySQL

2010-10-12 13:55:41

MySQL EXPLA

2022-11-05 08:37:00

MySQL數據索引

2021-09-16 06:44:07

數據庫SQL語句
點贊
收藏

51CTO技術棧公眾號

国产一本一道久久香蕉| 日韩高清三区| 亚洲精品亚洲人成人网 | 国产精品三级一区二区| 黄频在线免费观看| 视频一区中文字幕国产| 成年人精品视频| 妖精视频一区二区| 精品欧美一区二区三区在线观看| 亚洲欧美一区二区三区孕妇| 久久综合毛片| jizz中国女人| 日韩电影在线看| 国色天香2019中文字幕在线观看| 精品人妻中文无码av在线| 欧美午夜网站| 欧美天天综合网| 秋霞无码一区二区| 99福利在线| 欧美国产日韩在线观看| 精品国产免费人成电影在线观...| 亚洲怡红院av| 欧美亚洲免费| 午夜精品www| 色婷婷在线视频观看| 欧美一区 二区| 欧美一区二区三区成人| 久久久久久久久久久久久国产精品| 国产黄色在线观看| 国产欧美va欧美不卡在线| 国产视色精品亚洲一区二区| 国产喷水福利在线视频| 日本美女一区二区| 2020国产精品视频| 日韩精品成人在线| 欧美天天在线| 欧美精品一本久久男人的天堂| 亚洲精品视频网址| 国产亚洲电影| 亚洲网站在线播放| 色噜噜日韩精品欧美一区二区| 国产精品色呦| 精品电影一区二区| 日本网站在线看| 日韩五码电影| 在线不卡的av| 国产高清999| 懂色av色香蕉一区二区蜜桃| 欧美吞精做爰啪啪高潮| 成 人 黄 色 小说网站 s色| 欧美aaa级| 欧美三级视频在线观看| 91淫黄看大片| 欧美aa视频| 在线观看日韩电影| 午夜久久久精品| 欧美在线se| 69堂国产成人免费视频| 一级日本黄色片| 国产激情综合| 日韩欧美的一区| 久久久久久久久久影视| 中文字幕av一区二区三区四区| 欧美videofree性高清杂交| 国产精品日日摸夜夜爽| 国产伦理久久久久久妇女| 亚洲国产三级网| 熟女俱乐部一区二区| 女厕嘘嘘一区二区在线播放| 亚洲午夜精品久久久久久性色| 一本在线免费视频| 亚洲电影影音先锋| 久久久久久久激情视频| 欧美h在线观看| 日本不卡123| 91在线中文字幕| 黄色av小说在线观看| 91在线视频网址| 亚洲高清不卡一区| 18网站在线观看| 欧美日韩国产影院| 亚洲这里只有精品| av成人综合| 国产香蕉精品视频一区二区三区| 99热这里只有精品4| 亚洲午夜视频| 日韩av免费一区| 亚洲在线视频播放| av网站一区二区三区| 日韩美女一区| 日本福利在线| 午夜精品福利一区二区三区蜜桃| 红桃av在线播放| 国产麻豆一区二区三区| 日韩成人中文电影| 爱爱视频免费在线观看| 国产亚洲网站| 亚洲一区二区日本| 黄色av免费在线看| 亚洲在线一区二区三区| 亚洲不卡视频在线| 白白在线精品| 中文字幕日韩高清| 欧美不卡视频在线观看| 久久99精品国产麻豆不卡| 国产女主播一区二区| 色多多视频在线观看| 欧美日韩在线影院| 国产成人精品综合久久久久99| 国产不卡一二三区| 欧美激情综合色| 一级黄色片在线播放| 99免费精品视频| 51xx午夜影福利| 秋霞国产精品| 亚洲欧美另类国产| 国产午夜福利片| 激情久久五月天| 日韩啊v在线| 亚洲精品88| 欧美精品一区二区三| www.av免费| 免费观看30秒视频久久| 欧美日韩精品久久| 成人三级高清视频在线看| 欧美一级片在线| 九九热视频在线免费观看| 久久精品1区| 精品免费日产一区一区三区免费| 性网站在线观看| 91精品啪在线观看国产60岁| 日韩一级片在线免费观看| 久久精品1区| 欧美日韩国产精品一卡| 一区二区电影免费观看| 亚洲国产一区自拍| 九九九国产视频| 成人精品亚洲人成在线| 喜爱夜蒲2在线| 日韩精品一区国产| 欧美日本国产在线| 亚洲av无码国产精品久久不卡 | 久久久久亚洲av片无码下载蜜桃| 精品在线播放免费| 国产精品波多野结衣| 欧美成人xxxx| 日韩一区二区av| 国产口爆吞精一区二区| 亚洲欧美日韩国产一区二区三区| 成 人 黄 色 小说网站 s色| 国产韩日影视精品| 91亚洲精品在线| 在线你懂的视频| 精品国产精品一区二区夜夜嗨| 久久精品视频国产| 99精品久久只有精品| 九色在线视频观看| 国产一区不卡| 国产日韩在线观看av| 成人无遮挡免费网站视频在线观看| 91精品一区二区三区在线观看| 久久亚洲国产成人精品性色| 成人激情校园春色| 久久久精品在线视频| 精品一区二区三区的国产在线观看| 国产精品久久久久久亚洲影视 | 亚洲国产精品影院| 成年人在线观看av| 蜜臀久久久99精品久久久久久| 一区二区三区欧美在线| 麻豆精品在线| 91chinesevideo永久地址| 男人的天堂在线| 精品视频资源站| 538任你躁在线精品视频网站| 成人黄色在线视频| www.色就是色| 欧美激情偷拍| 欧美日韩在线精品一区二区三区| 韩国理伦片久久电影网| 欧美激情亚洲激情| 理论在线观看| 欧美一区二区三区免费大片 | 日韩va欧美va亚洲va久久| 中文字幕av日韩精品| 国产精品chinese在线观看| 欧美一区二区影院| 老司机精品视频在线观看6| 欧美精品一区二区久久久| 超碰在线观看91| 一级中文字幕一区二区| 欧美黄色一级生活片| 国产麻豆精品在线观看| 国产69精品久久久久999小说| 精品国产乱码久久久久久蜜坠欲下 | 日本一区二区高清不卡| 2020国产精品久久精品不卡| 日本不卡网站| 久久综合伊人77777| 青青草手机在线| 日韩视频国产视频| 伊人久久中文字幕| 午夜精品免费在线| 男人晚上看的视频| 久久午夜老司机| 潘金莲一级淫片aaaaaaa| 三级欧美在线一区| 日本精品久久久久久久久久| 水蜜桃久久夜色精品一区| 国产精品区免费视频| julia一区二区三区中文字幕| 久久久久女教师免费一区| 日本中文字幕电影在线免费观看| 日韩电影网在线| 国内毛片毛片毛片毛片| 欧美日韩视频一区二区| 黄色免费av网站| 亚洲国产美女搞黄色| 欧美风情第一页| 亚洲国产精品精华液ab| av小说在线观看| 不卡欧美aaaaa| 无套白嫩进入乌克兰美女| 青青草国产精品97视觉盛宴| 人妻av中文系列| 伊人天天综合| 国产成a人亚洲精v品在线观看| 日韩久久综合| 污视频在线免费观看一区二区三区| 日本国产精品| 国产伦精品一区二区三区高清| 国产精品麻豆| 成人欧美一区二区三区在线湿哒哒| 中文字幕乱码中文乱码51精品| 国模精品一区二区三区色天香| 羞羞电影在线观看www| 欧美成aaa人片免费看| 秋霞午夜在线观看| 日韩在线精品一区| 色欧美激情视频在线| 久久韩国免费视频| 久久综合网导航| 久久福利视频网| 二区在线播放| 欧美日本精品在线| 国精产品一区一区三区mba下载| 欧美夫妻性视频| 欧美性爽视频| 97色在线视频观看| 亚洲天堂手机| 国产精品成人品| 激情久久一区二区| 成人综合国产精品| 日韩欧美中文字幕在线视频| 99视频国产精品免费观看| 综合成人在线| 久久精品国产精品青草色艺 | 久久精品超碰| 国产日韩视频在线观看| 欧美欧美在线| 精品综合久久| 国产一区二区精品久| 亚洲精品成人a8198a| 天天综合国产| 日韩精品一区在线视频| 在线亚洲伦理| 91n.com在线观看| 国产一区久久久| 日韩成人av一区二区| 久久综合九色综合欧美亚洲| 免费看裸体网站| 亚洲人成网站色在线观看| 久久9999久久免费精品国产| 一本色道久久综合亚洲aⅴ蜜桃| 亚洲一区中文字幕永久在线| 日韩亚洲欧美中文三级| 亚洲欧美日韩免费| 日韩在线精品一区| 大桥未久在线视频| 国产美女直播视频一区| 日本高清精品| 欧美日韩综合网| 亚洲精品a级片| 亚欧无线一线二线三线区别| 久久成人久久鬼色| 黄色污在线观看| 国产精品久久免费看| 国产中文字字幕乱码无限| 日本道免费精品一区二区三区| 99久久精品国产色欲| 精品视频在线播放色网色视频| 乱人伦中文视频在线| 911国产网站尤物在线观看| 免费日韩成人| 久久综合狠狠综合久久综青草| 999国产精品视频| 国产精品宾馆在线精品酒店| 狠狠v欧美v日韩v亚洲ⅴ| 亚洲第一香蕉网| 一个色在线综合| 中文字幕观看在线| 亚洲国产成人爱av在线播放| 午夜老司机在线观看| 88xx成人精品| 在这里有精品| 男女h黄动漫啪啪无遮挡软件| 蜜桃视频一区| 黑丝av在线播放| 一区二区日韩电影| 国产又粗又猛又爽又黄的视频一| 日韩精品在线视频美女| 欧美人与牲禽动交com| 国产精品一区二区在线| 希岛爱理av免费一区二区| 毛片av在线播放| 国产在线观看一区二区| 天天干天天操天天拍| 欧美午夜片在线免费观看| 亚洲黄色在线观看视频| 蜜臀久久99精品久久久无需会员| 国产成人精品一区二区三区视频 | 中国美女乱淫免费看视频| 亚洲午夜一二三区视频| 国产男男gay网站| 深夜福利一区二区| 国产精品久久亚洲不卡| 久久综合福利| 久久都是精品| 中文天堂在线视频| 欧美日韩成人一区二区| 亚州视频一区二区三区| 欧美日韩成人黄色| 欧美国产中文高清| 四虎4hu永久免费入口| 极品少妇一区二区三区精品视频| 亚洲精品午夜视频| 91久久精品一区二区三| 你懂的视频在线| 欧美在线视频一区二区| 丝袜美腿一区二区三区动态图| 欧美精品久久久久久久自慰| 国产91丝袜在线观看| 精品99在线观看| 精品毛片乱码1区2区3区| 欧美人与禽猛交乱配| 国产精品一级久久久| 亚洲精品欧美| 中文字幕xxx| 在线视频一区二区三区| av在线首页| 成人国产精品色哟哟| 亚洲一区二区三区| 潘金莲一级淫片aaaaa| 午夜国产精品一区| 欧美美女色图| 国产精品直播网红| 亚洲大全视频| 国产a√精品区二区三区四区| 亚洲福利一区二区三区| 亚洲 欧美 激情 另类| 青青在线视频一区二区三区| av资源久久| 超碰中文字幕在线观看| 亚洲国产日韩精品| 四虎精品在永久在线观看 | 69堂免费精品视频在线播放| 色一情一乱一伦一区二区三区丨 | 精品久久久久久亚洲| 性8sex亚洲区入口| 秋霞网一区二区三区| 欧美成人午夜电影| 日韩伦理精品| 在线成人av电影| 大尺度一区二区| 日本黄色中文字幕| 久久成人一区二区| 欧美男人操女人视频| 亚洲色图久久久| 一区二区国产盗摄色噜噜| 免费在线观看一级毛片| 成人免费网站在线看| 日韩午夜电影| 亚洲熟女毛茸茸| 日韩av在线免费看| 久久91视频| 欧美视频在线观看网站| 国产精品麻豆欧美日韩ww| 亚洲AV无码精品自拍| 国产精品video| 亚洲精品精选| 国精产品一区一区二区三区mba | 中文字幕av网址| 日韩视频在线永久播放| 手机在线观看av| 欧美日韩一级在线 | 欧美日韩中文字幕在线观看| 亚洲精品一区二三区不卡| 久久九九精品视频| 好男人www社区| 精品成人久久av|