欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL索引下推(ICP)的簡單理解與示例

 更新時間:2021年09月09日 15:04:52   作者:毛英東  
大家應(yīng)該都知道索引下推可以提高查詢效率,所以下面這篇文章主要給大家介紹了關(guān)于MySQL索引下推(ICP)的簡單理解與示例的相關(guān)資料,需要的朋友可以參考下

前言

索引下推(Index Condition Pushdown, 簡稱ICP)是MySQL 5.6 版本的新特性,它能減少回表查詢次數(shù),提升檢索效率。

MySQL體系結(jié)構(gòu)

要明白索引下推,首先要了解MySQL的體系結(jié)構(gòu):

上圖來自MySQL官方文檔

通常把MySQL從上至下分為以下幾層:

  • MySQL服務(wù)層:包括NoSQL和SQL接口、查詢解析器、優(yōu)化器、緩存和Buffer等組件。
  • 存儲引擎層:各種插件式的表格存儲引擎,實現(xiàn)事務(wù)、索引等各種存儲引擎相關(guān)的特性。
  • 文件系統(tǒng)層: 讀寫物理文件。

MySQL服務(wù)層負(fù)責(zé)SQL語法解析、觸發(fā)器、視圖、內(nèi)置函數(shù)、binlog、生成執(zhí)行計劃等,并調(diào)用存儲引擎層去執(zhí)行數(shù)據(jù)的存儲和檢索?!八饕峦啤钡摹跋隆逼鋵嵕褪侵笇⒉糠稚蠈樱ǚ?wù)層)負(fù)責(zé)的事情,交給了下層(存儲引擎)去處理。

索引下推案例

假設(shè)用戶表數(shù)據(jù)和結(jié)構(gòu)如下:

id age birthday name
1 18 01-01 User1
2 19 03-01 User2
3 20 03-01 User3
4 21 03-01 User4
5 22 05-01 User5
6 18 06-01 User6
7 24 01-01 User7

創(chuàng)建一個聯(lián)合索引(age, birthday),并查詢出年齡>20,且生日為03-01的用戶:

select * from user where age>20 and birthday="03-01"

由于age字段使用了范圍查詢,根據(jù)最左前綴原則,這種情況只能使用age字段進(jìn)行范圍查詢,索引中的birthday字段無法使用。使用explain查看執(zhí)行計劃:

+------+-------------+-------+-------+---------------+--------------+---------+------+------+-----------------------+
| id   | select_type | table | type  | possible_keys | key          | key_len | ref  | rows | Extra                 |
+------+-------------+-------+-------+---------------+--------------+---------+------+------+-----------------------+
|    1 | SIMPLE      | user  | range | age_birthday  | age_birthday | 4       | NULL | 3    | Using index condition |
+------+-------------+-------+-------+---------------+--------------+---------+------+------+-----------------------+

可以看到雖然使用了age_birthday索引,但是索引長度key_len只有4,說明只有聯(lián)合索引只有age字段生效了(因為age字段是int類型,占用4個字節(jié))。最后Extra列的Using index condition表示這個查詢使用了索引下推優(yōu)化。

為在沒有索引下推的情況下,執(zhí)行步驟如下:

  • 存儲引擎根據(jù)索引查找出age>20的用戶id,分別是:4,5,7
  • 存儲引擎到表格中取出id in (4,5,7)的3條記錄,返回給服務(wù)層
  • 服務(wù)層過濾掉不符合birthday="03-01"條件的記錄,最后返回查詢結(jié)果為id=4的1行記錄。

如果開啟了索引下推優(yōu)化,執(zhí)行步驟如下:

  1. 存儲引擎根據(jù)索引查找出age>20的用戶id,并使用索引中的birthday字段過濾掉不符合birthday="03-01"條件的記錄,最后得到id=4;
  2. 存儲引擎到表格中取出id=4的1條記錄,返回給服務(wù)層;
  3. 服務(wù)層過濾掉不符合birthday="03-01"條件的記錄,最后返回查詢結(jié)果為id=4的1行記錄。

啟用索引下推后,把where條件由MySQL服務(wù)層放到了存儲引擎層去執(zhí)行,帶來的好處就是存儲引擎根據(jù)id到表格中讀取數(shù)據(jù)的次數(shù)變少了。在上面這個例子中,沒有索引下推時需要多回表查詢2次。并且回表查詢很可能是離散IO,在某些情況下,對數(shù)據(jù)庫性能會有較大提升。

總結(jié)

到此這篇關(guān)于MySQL索引下推(ICP)的簡單理解與示例的文章就介紹到這了,更多相關(guān)MySQL索引下推(ICP)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解MySQL 表中非主鍵列溢出情況監(jiān)控

    詳解MySQL 表中非主鍵列溢出情況監(jiān)控

    這篇文章主要介紹了詳解MySQL 表中非主鍵列溢出情況監(jiān)控,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • mysql表添加索引的幾種實現(xiàn)方法

    mysql表添加索引的幾種實現(xiàn)方法

    本文介紹了在MySQL中使用ALTER?TABLE語句為表添加索引的幾種常見方式,包括普通索引、唯一索引、主鍵索引和全文索引,感興趣的可以了解一下
    2024-11-11
  • Linux中部署MySQL環(huán)境的四種方式圖文詳解

    Linux中部署MySQL環(huán)境的四種方式圖文詳解

    這篇文章主要介紹了Linux中部署MySQL環(huán)境的四種方式,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-11-11
  • 真的了解MySQL中的binlog和redolog區(qū)別

    真的了解MySQL中的binlog和redolog區(qū)別

    MySQL的binlog和redolog都是用于記錄數(shù)據(jù)庫操作的日志文件,但是它們有不同的作用和特點,今天給大家分享MySQL的binlog和redolog區(qū)別,感興趣的朋友一起看看吧
    2023-11-11
  • Navicat for SQLite導(dǎo)入csv中文數(shù)據(jù)的方法

    Navicat for SQLite導(dǎo)入csv中文數(shù)據(jù)的方法

    這篇文章主要為大家詳細(xì)介紹了Navicat for MySql導(dǎo)入.CSV文件的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • Linux7操作系統(tǒng)中如何安裝MySQL5.6

    Linux7操作系統(tǒng)中如何安裝MySQL5.6

    這篇文章主要介紹了Linux7操作系統(tǒng)中如何安裝MySQL5.6問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Can't connect to MySQL server on localhost (10061)解決方法

    Can't connect to MySQL server 

    今天在安裝mysql后使用mysql命令連接mysql時報錯?Can't connect to MySQL server on localhost (10061),一般是因為mysql服務(wù)沒有啟動或者用戶名密碼不正確
    2011-03-03
  • MySQL中二進(jìn)制與重做日志文件的基本概念學(xué)習(xí)教程

    MySQL中二進(jìn)制與重做日志文件的基本概念學(xué)習(xí)教程

    這篇文章主要介紹了MySQL中二進(jìn)制日志文件與重做日志文件的基本概念學(xué)習(xí)教程,講到了一些重做日志與二進(jìn)制日志的區(qū)別,需要的朋友可以參考下
    2015-11-11
  • 如何合理使用數(shù)據(jù)庫冗余字段的方法

    如何合理使用數(shù)據(jù)庫冗余字段的方法

    今天小編就為大家分享一篇關(guān)于如何合理使用數(shù)據(jù)庫冗余字段的方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • MySQL配置文件my.ini的使用解讀

    MySQL配置文件my.ini的使用解讀

    這篇文章主要介紹了MySQL配置文件my.ini的使用解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12

最新評論