雜湊索引在MySQL中的探究
導讀 | 什麼是自適應雜湊索引(Adaptive Hash Index, AHI)呢?原理又是怎樣的呢?下面我們先從一個例子開始。 |
經常有朋友問,MySQL的InnoDB到底支不支援雜湊索引?
對於InnoDB的雜湊索引,確切的應該這麼說:
(1)InnoDB使用者無法手動建立雜湊索引,這一層上說,InnoDB確實不支援雜湊索引;
(2)InnoDB會自調優(self-tuning),如果判定建立自適應雜湊索引(Adaptive Hash Index, AHI),能夠提升查詢效率,InnoDB自己會建立相關雜湊索引,這一層上說,InnoDB又是支援雜湊索引的;
那什麼是自適應雜湊索引(Adaptive Hash Index, AHI)呢?原理又是怎樣的呢?我們們先從一個例子開始。
不妨設有InnoDB資料表:
t(id PK, name KEY, sex, flag)
畫外音:id是主鍵,name建了普通索引。 假設表中有四條記錄:
- 1, shenjian, m, A
- 3, zhangsan, m, A
- 5, lisi, m, A
- 9, wangwu, f, B
如上圖,透過前序知識,容易知道InnoDB在主鍵id上會建立聚集索引(Clustered Index),葉子儲存記錄本身,在name上會建立普通索引(Secondary Index),葉子儲存主鍵值。
發起主鍵id查詢時,能夠透過聚集索引,直接定位到行記錄。
select * from t where name='ls';
發起普通索引查詢時:
(1)會先從普通索引查詢出主鍵(上圖右邊);
(2)再由主鍵,從聚集索引上二次遍歷定位到記錄(上圖左邊)。
不管聚集索引還是普通索引,記錄定位的尋路路徑(Search Path)都很長。
在MySQL執行的過程中,如果InnoDB發現,有很多SQL存在這類很長的尋路,並且有很多SQL會命中相同的頁面(page),InnoDB會在自己的記憶體緩衝區(Buffer)裡,開闢一塊區域,建立自適應雜湊所有AHI,以加速查詢。
從這個層面上來說,InnoDB的自使用雜湊索引,更像“索引的索引”,畢竟其目的是為了加速索引尋路。
既然是雜湊,key是什麼,value是什麼?
key是索引鍵值(或者鍵值字首)。
value是索引記錄頁面位置。
為啥叫“自適應(adaptive)”雜湊索引?
系統自己判斷“應該可以加速查詢”而建立的,不需要使用者手動建立,故稱“自適應”。
系統會不會判斷失誤,是不是一定能加速?
不是一定能加速,有時候會誤判。 當業務場景為下面幾種情況時:
(1)很多單行記錄查詢(例如passport,使用者中心等業務);
(2)索引範圍查詢(此時AHI可以快速定位首行記錄);
(3)所有記錄記憶體能放得下;
AHI往往是有效的。
畫外音:任何脫離業務的技術方案,都是耍流氓。
當業務有大量like或者join,AHI的維護反而可能成為負擔,降低系統效率,此時可以手動關閉AHI功能。
一個小知識點,希望對大家有幫助。
知其然,知其所以然。
原文來自:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69955379/viewspace-2893360/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- mysql中雜湊索引的使用限制MySql索引
- MySQL複合索引探究MySql索引
- js 雜湊雜湊值的模組JS
- MySQL自適應雜湊索引的特點和缺陷介紹和歸納MySql索引
- Mysql InnoDB B+樹索引和雜湊索引的區別? MongoDB 為什麼使用B-樹?MySql索引MongoDB
- 雜湊競猜遊戲系統開發原理方案探究遊戲
- 雜湊資料結構以及在HashMap中的應用資料結構HashMap
- InnoDB儲存引擎——自適應雜湊索引儲存引擎索引
- mysql覆蓋索引高效能的探究MySql索引
- 雜湊表(雜湊表)詳解
- SQL Server2014 雜湊索引原理SQLServer索引
- 雜湊
- 安全的雜湊
- [PHP核心探索]PHP中的雜湊表PHP
- 在Java中,HashMap中是用哪些方法來解決雜湊衝突的?JavaHashMap
- 雜湊表(雜湊表)原理詳解
- 【尋跡#3】 雜湊與雜湊表
- 第41期:MySQL 雜湊分割槽表MySql
- 查詢(3)--雜湊表(雜湊查詢)
- 幾道和雜湊(雜湊)表有關的面試題面試題
- 雜湊遊戲之雜湊盒子的趨勢未來可期遊戲
- 雜湊表的原理
- PHP核心探索之PHP中的雜湊表PHP
- 樹雜湊
- 雜湊碰撞
- 字串雜湊字串
- 雜湊表
- Qt 中實現非同步雜湊器QT非同步
- 22 | 雜湊演算法(下):雜湊演算法在分散式系統中有哪些應用?演算法分散式
- 雜湊函式函式
- 字串雜湊表字串
- redis之雜湊Redis
- 雜湊連線
- 6.7雜湊表
- 雜湊衝突
- 異或雜湊
- 探究MySQL中的日誌檔案MySql
- 探究MySQL中SQL查詢的成本MySql