<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
提到 limit 優化,大多數 MySQL DBA 都不會陌生,能想到各種應對策略,比如延遲關聯,書籤式查詢等等,之前我也寫過一篇優化的文章:https://www.jb51.net/article/234357.htm ,有興趣的朋友可以複習一下。
對於 limit N 帶有 group by ,order by 的 SQL 語句 (order by 和 group by 的欄位有索引可以使用),MySQL 優化器會盡可能選擇利用現有索引的有序性,減少排序–這看起來是 SQL 的執行計劃的最優解,但是實際上效果其實是南轅北轍,相信很多 DBA 遇到的相關案例中 sql 執行計劃選擇 order by id 的索引進而導致全表掃描,而不是利用 where 條件中的索引查詢過濾資料。MySQL 8.0.21 版本之前,並沒有什麼引數來控制這種行為,但是自 MySQL 8.0.21 之後提供一個優化器引數 prefer_ordering_index
,通過設定 optimizer_switch
來開啟或者關閉該特性 。 比如:
SET optimizer_switch = "prefer_ordering_index=off"; SET optimizer_switch = "prefer_ordering_index=on";
測試環境 MySQL 社群版 8.0.30
構造測試資料
CREATE TABLE t ( id1 BIGINT NOT NULL PRIMARY KEY auto_increment, id2 BIGINT NOT NULL, c1 VARCHAR(50) NOT NULL, c2 varchar(50) not null, INDEX i (id2, c1)); insert into t(id2,c1,c2) values(1,'a','xfvs'),(2,'bbbb','xfvs'),(3,'cdddd','xfvs'),(4,'dfdf','xfvs'),(12,'bbbb','xfvs'),(23,'cdddd','xfvs'),(14,'dfdf','xfvs'), (11,'bbbb','xfvs'),(13,'cdddd','xfvs'),(44,'dfdf','xfvs'),(31,'bbbb','xfvs'),(33,'cdddd','xfvs'),(34,'dfdf','xfvs');
mysql (test) > SELECT @@optimizer_switch LIKE '%prefer_ordering_index=on%'; +------------------------------------------------------+ | @@optimizer_switch LIKE '%prefer_ordering_index=on%' | +------------------------------------------------------+ | 1 | +------------------------------------------------------+ 1 row in set (0.00 sec)
查詢非索引欄位 ,id2 上有索引 ,order by 主鍵 id1 ,explain 檢視執行計劃 type index 說明使用索引掃描使用 using where 過濾結果集。這個是優化器的自以為的最優選擇,但是實際上遇到資料集合比較大的表,該執行計劃就不是最優解,反而導致慢查。
mysql (test) > explain select c2 from t where id2>8 ORDER BY id1 ASC LIMIT 2G *************************** 1. row *************************** id: 1 select_type: SIMPLE table: t partitions: NULL type: index possible_keys: i key: PRIMARY key_len: 8 ref: NULL rows: 2 filtered: 69.23 Extra: Using where 1 row in set, 1 warning (0.00 sec)
mysql (test) > SET optimizer_switch = "prefer_ordering_index=off"; mysql (test) > explain select c2 from t where id2>8 ORDER BY id1 ASC LIMIT 2G *************************** 1. row *************************** id: 1 select_type: SIMPLE table: t partitions: NULL type: range possible_keys: i key: i key_len: 8 ref: NULL rows: 9 filtered: 100.00 Extra: Using index condition; Using filesort 1 row in set, 1 warning (0.00 sec)
經過調整之後,檢視執行計劃發現優化器選擇 id2 索引欄位找到記錄做過濾,並且使用了ICP 特性,減少物理 io 請求,而不是選擇使用主鍵 id1 遍歷索引然後回表查詢。
顯然 通過人為介入引數調整優化器的行為能帶來更好的優化效果。
從不同版本的 MySQL 發展軌跡來看 MySQL 的優化器越來越智慧 (比如大家期待已久的直方圖特性) ,能更多的減少人為干預,提升執行計劃的準確性。
到此這篇關於MySQL 8.0 對 limit 的優化的文章就介紹到這了,更多相關MySQL 8.0 limit優化內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45