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

MySQL存儲引擎的實現(xiàn)要素分析

 更新時間:2023年09月14日 14:13:01   作者:jump__jump  
這篇文章主要為大家介紹了MySQL存儲引擎的實現(xiàn)要素分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

引言

眾所周知,MySQL 的 InnoDB 存儲引擎使用了 B+ 樹作為索引實現(xiàn),那么為什么不使用其他的數(shù)據(jù)結構呢?數(shù)組、鏈表或者哈希表。實現(xiàn)存儲引擎究竟需要什么條件呢?

我們現(xiàn)在先以存儲最簡單的數(shù)據(jù)為例,這里的數(shù)據(jù)類似于 json 對象。有 key 和 value。

{
    "0": "value1",
    "1": "value2" 
}

最簡單的存儲引擎必須實現(xiàn)以下三個方法:

  • read: (key: number) => value 查找 key 并返回 value
  • write: (key: number, value) => void 查找并插入 key 以及 value
  • scan: (begin: number, end: number) => value[] 查找返回 key 范圍內(nèi)數(shù)據(jù)

簡單數(shù)據(jù)結構

對于開發(fā)項目來說,能使用最簡單的數(shù)據(jù)結構完成項目是非常棒的,這意味著更少的 bug 和更少的時間。

有序數(shù)組

如果當前有序數(shù)組的位置和存儲的 key 可以一一對應的話,也就是數(shù)組 index 對應 key(沒有對應也就是稀疏數(shù)組),我們的 read 和 write 方法的時間復雜度會是 O(1),scan 方法也是 O(1)。但數(shù)據(jù)量稍大就扛不住了。

退而求其次,不存在位置對應主鍵的情況下,有序數(shù)組緊密存儲,這樣可以通過二分查找,read 和 scan 方法的時間復雜度為 O(log2n)。但 write 方法成本會高到離譜。

綜上所屬,有序數(shù)組是在數(shù)據(jù)量少的情況下可以用來做存儲引擎的。

哈希表

不考慮空間是不可能的,那么直接舍棄 scan 方法呢?在某些業(yè)務場景下是可以不使用 scan 方法的。

哈希表使用一對多的組織方式來實現(xiàn) read 和 write。先對 key 進行 hash 運算然后再尋址,性能基本接近于 O(1)。

綜上所屬,哈希表在不考慮 scan 方法的情況下是可以用來做存儲引擎的。

二叉平衡樹

二叉平衡樹相對 hash 和有序數(shù)據(jù)來說是一個折衷方案。該數(shù)據(jù)結構是通過鏈表實現(xiàn)的,所以不需要大塊內(nèi)存。它的 read 和 write 都是 O(log2n),雖然 scan 遍歷慢的難以忍受,但是它能夠?qū)崿F(xiàn)這三個方法了。

綜上所屬,二叉平衡樹是可以用來做存儲引擎的,但有一定的局限性。

要素分析

在分析上面幾種數(shù)據(jù)結構后,我們不難得出結論。

  • 有序性是實現(xiàn) scan 方法的前提條件
  • 局部性是提升 scan/read 方法性能的必要條件

這里我們提到了局部性,那么局部性究竟是什么呢?

通常來說,良好的計算機程序需要良好的局部性,局部性主要有:

  • 時間局部性 :指的是同一個內(nèi)存位置,從時間維度來看,它能夠在較短時間內(nèi)被多次引用
  • 空間局部性 :指的是同一個內(nèi)存位置,從空間維度來看,它附近的內(nèi)存位置能夠被引用

仔細分析一下,scan 方法和空間局部性有關。如果使用平衡二叉樹來作為查詢的數(shù)據(jù)結構。scan 的性能是非常差的,但是使用有序數(shù)組來作為數(shù)據(jù)結構 scan 可以直接遍歷獲取兩者之間的數(shù)據(jù),性能非常高。

同時,局部性也和 read 性能有很大關系。使用二分法來查詢數(shù)據(jù)。局部性較低的情況下,read 需要多次從磁盤加載數(shù)據(jù)。如果局部性高,直接一次加載數(shù)據(jù)即可。

那是不是局部性越高越好呢?不是這樣的。一方面局部性高會占用較高的內(nèi)存。另一方面,局部性過高會導致 write 方法變慢,因為局部性高了,write 方法需要移動的數(shù)據(jù)也就多了。

平衡二叉樹是唯一能在現(xiàn)實世界中實現(xiàn) 3 個方法的數(shù)據(jù)結構,局部性是提升 scan 方法性能的必要條件。那么把兩者結合呢?把平衡二叉樹的結點構造成一個個有序數(shù)組,這樣就可以得到兩個方案的優(yōu)點了。

  • 對于有序數(shù)組來說,通過拆分數(shù)組,使得在 write 方法的成本大大減少
  • 對于平衡二叉樹來說,通過節(jié)點替換,大大增加了局部性,讓 scan 方法性能成本大大減少

事實上,只要能夠低成本且高效的維持數(shù)據(jù)有序的數(shù)據(jù)結構都可以作為存儲引擎。無論是 B 樹, B+ 樹或者 跳表。同時每個數(shù)據(jù)結構都有其對應的側(cè)重點。只要抓住這幾個點,就不難分析出為什么當前存儲引擎使用該數(shù)據(jù)結構作為索引了。

以上就是MySQL存儲引擎的實現(xiàn)要素分析的詳細內(nèi)容,更多關于MySQL存儲引擎的資料請關注腳本之家其它相關文章!

相關文章

  • Win中安裝mysql的詳細步驟

    Win中安裝mysql的詳細步驟

    這篇文章主要為大家詳細介紹了Win中安裝mysql的詳細步驟,文中安裝步驟介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • MySQL數(shù)據(jù)庫中數(shù)值字段類型長度int(11)和Decimal(M,D)詳解

    MySQL數(shù)據(jù)庫中數(shù)值字段類型長度int(11)和Decimal(M,D)詳解

    這篇文章主要介紹了MySQL數(shù)據(jù)庫中數(shù)值字段類型長度int(11)和Decimal(M,D)字段詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • CentOS下重置MySQL的root密碼的教程

    CentOS下重置MySQL的root密碼的教程

    這篇文章主要介紹了CentOS下重置MySQL的root密碼的教程,首先要擁有系統(tǒng)的root權限,最后還附屬了一個使用mysqladmin下的方法,需要的朋友可以參考下
    2015-11-11
  • MySQL數(shù)據(jù)庫遷移全過程

    MySQL數(shù)據(jù)庫遷移全過程

    本文詳細解析了MySQL數(shù)據(jù)庫遷移的整個過程,包括準備工作、遷移方法、注意事項和優(yōu)缺點,文章介紹了三種常見的遷移方法:使用mysqldump導出和導入、使用ibd文件遷移和使用目錄整體遷移,每種方法都有其優(yōu)缺點,選擇合適的方法取決于具體的遷移需求和環(huán)境
    2025-02-02
  • MySql減少內(nèi)存占用的方法詳解

    MySql減少內(nèi)存占用的方法詳解

    這篇文章主要介紹了MySql減少內(nèi)存占用的方法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-07-07
  • mysql導出查詢結果到csv的實現(xiàn)方法

    mysql導出查詢結果到csv的實現(xiàn)方法

    下面小編就為大家?guī)硪黄猰ysql導出查詢結果到csv的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • windows下mysql?8.0.27?安裝配置方法圖文教程

    windows下mysql?8.0.27?安裝配置方法圖文教程

    這篇文章主要為大家詳細介紹了windows下mysql?8.0.27?安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • MySQL中觸發(fā)器和游標的介紹與使用

    MySQL中觸發(fā)器和游標的介紹與使用

    這篇文章主要給大家介紹了關于MySQL中觸發(fā)器和游標的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • mysql壓力測試腳本實例

    mysql壓力測試腳本實例

    這篇文章主要介紹了mysql壓力測試腳本,實例展示了實現(xiàn)MySQL壓力測試的完整方法,需要的朋友可以參考下
    2014-11-11
  • SQL?ALTER?TABLE語句靈活修改表結構和數(shù)據(jù)類型

    SQL?ALTER?TABLE語句靈活修改表結構和數(shù)據(jù)類型

    這篇文章主要介紹了SQL?ALTER?TABLE語句靈活修改表結構和數(shù)據(jù)類型,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12

最新評論