Mysql性能優化:什麼是索引下推?

来源:https://www.cnblogs.com/Chenjiabing/archive/2020/03/30/12600926.html
-Advertisement-
Play Games

導讀 本文章始發於本人公眾號:碼猿技術專欄,原創不易,謝謝關註推薦。 索引下推(index condition pushdown )簡稱ICP,在Mysql5.6的版本上推出,用於優化查詢。 在不使用ICP的情況下,在使用非主鍵索引(又叫普通索引或者二級索引)進行查詢時,存儲引擎通過索引檢索到數據, ...


導讀

  • 本文章始發於本人公眾號:碼猿技術專欄,原創不易,謝謝關註推薦。
  • 索引下推(index condition pushdown )簡稱ICP,在Mysql5.6的版本上推出,用於優化查詢。

  • 在不使用ICP的情況下,在使用非主鍵索引(又叫普通索引或者二級索引)進行查詢時,存儲引擎通過索引檢索到數據,然後返回給MySQL伺服器,伺服器然後判斷數據是否符合條件 。

  • 在使用ICP的情況下,如果存在某些被索引的列的判斷條件時,MySQL伺服器將這一部分判斷條件傳遞給存儲引擎,然後由存儲引擎通過判斷索引是否符合MySQL伺服器傳遞的條件,只有當索引符合條件時才會將數據檢索出來返回給MySQL伺服器 。

  • 索引條件下推優化可以減少存儲引擎查詢基礎表的次數,也可以減少MySQL伺服器從存儲引擎接收數據的次數

 

開擼

  • 在開始之前先先準備一張用戶表(user),其中主要幾個欄位有:id、name、age、address。建立聯合索引(name,age)

  • 假設有一個需求,要求匹配姓名第一個為陳的所有用戶,sql語句如下:

  SELECT * from user where  name like '陳%'
  • 根據 "最佳左首碼" 的原則,這裡使用了聯合索引(name,age)進行了查詢,性能要比全表掃描肯定要高。

  • 問題來了,如果有其他的條件呢?假設又有一個需求,要求匹配姓名第一個字為陳,年齡為20歲的用戶,此時的sql語句如下:

  SELECT * from user where  name like '陳%' and age=20
  • 這條sql語句應該如何執行呢?下麵對Mysql5.6之前版本和之後版本進行分析。

 

Mysql5.6之前的版本

  • 5.6之前的版本是沒有索引下推這個優化的,因此執行的過程如下圖:

 

  • 會忽略age這個欄位,直接通過name進行查詢,在(name,age)這課樹上查找到了兩個結果,id分別為2,1,然後拿著取到的id值一次次的回表查詢,因此這個過程需要回表兩次

 

Mysql5.6及之後版本

  • 5.6版本添加了索引下推這個優化,執行的過程如下圖:

  • InnoDB並沒有忽略age這個欄位,而是在索引內部就判斷了age是否等於20,對於不等於20的記錄直接跳過,因此在(name,age)這棵索引樹中只匹配到了一個記錄,此時拿著這個id去主鍵索引樹中回表查詢全部數據,這個過程只需要回表一次

 

實踐

  • 當然上述的分析只是原理上的,我們可以實戰分析一下,因此陳某裝了Mysql5.6版本的Mysql,解析了上述的語句,如下圖:

  • 根據explain解析結果可以看出Extra的值為Using index condition,表示已經使用了索引下推。

 

總結

  • 索引下推在非主鍵索引上的優化,可以有效減少回表的次數,大大提升了查詢的效率。

  • 關閉索引下推可以使用如下命令,配置文件的修改不再講述了,畢竟這麼優秀的功能幹嘛關閉呢:

  set optimizer_switch='index_condition_pushdown=off';

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 文件類型說明: ls –l顯示文件詳細信息中: 說明:10個字元,第一個字元表示文件類型,後面9個字元表示文件許可權。 訪問許可權:可讀(r)、可寫(w)和可執行(x)。 用戶級別:文件擁有者(u)、所屬的用戶組(g)和系統中的其他用戶(o)。 第一個字元顯示文件的類型如下: “-”表示普通文件。 “d ...
  • (1) ls(list,列表) 作用:使用列表把當前文件夾下所有文件顯示出來 ls -a 顯示所有文件,包括隱藏文件(以“.”開頭的文件) ls -l 詳細信息顯示文件 ls -a -l ls -l -a ls -la (2) cd (change directory,更改目錄) 作用:用來切換目錄 ...
  • 不知道大家接觸 Linux 系統有多久了,可曾瞭解過 Linux 中有哪些特殊的字元呢?其實啊,那些特殊字元都大有用處呢,今天的文章就給大家簡單地科普一下 Linux 中你需要瞭解的 15 個特殊字元,想學或剛學 Linux 的小伙伴趕緊上車了為! ~ 主目錄 這個波浪號 ~ 指的是 主目錄 ,也就 ...
  • 1. 查看當前kernel版本 2. 查看已安裝版本 3. 查看可升級kernel版本 4. 升級kernel版本 5. 刪除舊的內核 方法一:安裝yum utls: 設置你想要保留多少舊的內核,比如我想保留兩個: 方法二:直接刪除對應版本 6. 設置永久的內核安裝數量 設置installonly_ ...
  • ==共耗時10多個小時== 思路一 總體設計 ansible playbook目錄結構 入口文件 執行與結果 實現過程問題記錄 tomcat應用程式是root用戶啟動的,root用戶啟動tomcat有一個嚴重的問題,那就是tomcat具有root許可權,這意味著你的任何一個頁面腳本(html/js)都 ...
  • 作為一名小白,今天開始上傳自己的學習總結。 ...
  • 1.在Redis 目錄下複製redis.windows-service.conf文件,建議命名規則redis.windows-service-port.conf,我們以6380埠為例。 2.打開redis.windows-service-6380配置文件。 修改埠port 修改資料庫名稱dbfi ...
  • 在工作中遇到的一些關於Sql查詢的問題整理記錄,實現環境 SQLService 2014 一、對同一個欄位,多個關鍵詞的查詢幾種實現方式 基本語法: SELECT column_name(s) FROM table_name WHERE column_name LIKE pattern 案例表(Tb ...
一周排行
    -Advertisement-
    Play Games
  • C#TMS系統代碼-基礎頁面BaseCity學習 本人純新手,剛進公司跟領導報道,我說我是java全棧,他問我會不會C#,我說大學學過,他說這個TMS系統就給你來管了。外包已經把代碼給我了,這幾天先把增刪改查的代碼背一下,說不定後面就要趕鴨子上架了 Service頁面 //using => impo ...
  • 委托與事件 委托 委托的定義 委托是C#中的一種類型,用於存儲對方法的引用。它允許將方法作為參數傳遞給其他方法,實現回調、事件處理和動態調用等功能。通俗來講,就是委托包含方法的記憶體地址,方法匹配與委托相同的簽名,因此通過使用正確的參數類型來調用方法。 委托的特性 引用方法:委托允許存儲對方法的引用, ...
  • 前言 這幾天閑來沒事看看ABP vNext的文檔和源碼,關於關於依賴註入(屬性註入)這塊兒產生了興趣。 我們都知道。Volo.ABP 依賴註入容器使用了第三方組件Autofac實現的。有三種註入方式,構造函數註入和方法註入和屬性註入。 ABP的屬性註入原則參考如下: 這時候我就開始疑惑了,因為我知道 ...
  • C#TMS系統代碼-業務頁面ShippingNotice學習 學一個業務頁面,ok,領導開完會就被裁掉了,很突然啊,他收拾東西的時候我還以為他要旅游提前請假了,還在尋思為什麼回家連自己買的幾箱飲料都要叫跑腿帶走,怕被偷嗎?還好我在他開會之前拿了兩瓶芬達 感覺感覺前面的BaseCity差不太多,這邊的 ...
  • 概述:在C#中,通過`Expression`類、`AndAlso`和`OrElse`方法可組合兩個`Expression<Func<T, bool>>`,實現多條件動態查詢。通過創建表達式樹,可輕鬆構建複雜的查詢條件。 在C#中,可以使用AndAlso和OrElse方法組合兩個Expression< ...
  • 閑來無聊在我的Biwen.QuickApi中實現一下極簡的事件匯流排,其實代碼還是蠻簡單的,對於初學者可能有些幫助 就貼出來,有什麼不足的地方也歡迎板磚交流~ 首先定義一個事件約定的空介面 public interface IEvent{} 然後定義事件訂閱者介面 public interface I ...
  • 1. 案例 成某三甲醫預約系統, 該項目在2024年初進行上線測試,在正常運行了兩天後,業務系統報錯:The connection pool has been exhausted, either raise MaxPoolSize (currently 800) or Timeout (curren ...
  • 背景 我們有些工具在 Web 版中已經有了很好的實踐,而在 WPF 中重新開發也是一種費時費力的操作,那麼直接集成則是最省事省力的方法了。 思路解釋 為什麼要使用 WPF?莫問為什麼,老 C# 開發的堅持,另外因為 Windows 上已經裝了 Webview2/edge 整體打包比 electron ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...