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

Mysql?InnoDB引擎中頁目錄和槽的查找過程

 更新時(shí)間:2022年05月31日 10:38:10   作者:把蘋果咬哭的測(cè)試筆記  
這篇文章主要為大家介紹了Mysql?InnoDB引擎中頁目錄和槽的查找記錄過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

Mysql InnoDB引擎頁目錄

一、頁目錄和槽

接上一篇,現(xiàn)在知道記錄在頁中按照主鍵大小順序串成了單鏈表。

那么我使用主鍵查詢的時(shí)候,最順其自然的辦法肯定是從第一條記錄,也就是 Infrimum 記錄開始,一直向后找,只要存在總會(huì)找到。這種在數(shù)據(jù)量少的時(shí)候還好說,一旦數(shù)據(jù)多了,遍歷耗時(shí)一定非常長(zhǎng)。

于是,作者又想到了一個(gè)好辦法,靈感來自于書本中的目錄。我們翻書的時(shí)候想查找一些內(nèi)容,就會(huì)去查看目錄,然后直接確定好內(nèi)容所在的頁碼。

那么對(duì)于 InnoDB 來說,過程如下:

  • 將所有正常的記錄劃分為幾個(gè)組,這里包括那 2 條虛擬記錄,但是不包含已經(jīng)被移除到垃圾鏈表的記錄。
  • 每個(gè)組內(nèi)最后一條記錄(也就是最大的那條)就是“大哥”,其他記錄都是“小弟”,而“大哥”記錄的頭信息中的 n_owned 屬性表示該組內(nèi)共有幾條記錄。
  • 將每個(gè)組中最后一條記錄在頁面中的地址偏移量單獨(dú)提取出來,按順序存儲(chǔ)到靠近頁尾部的地方。

這個(gè)地方就是頁目錄 Page Directory。而上述的地址偏移量就是該記錄的真實(shí)數(shù)據(jù)與頁面中第 0 個(gè)字節(jié)之間的距離,這些地址偏移量被稱為槽。

每個(gè)槽占用 2 字節(jié),頁目錄就是由多個(gè)槽組成。

二、頁目錄的規(guī)定

在上一篇中,創(chuàng)建的表里存在 4 條數(shù)據(jù),那么在頁中還要算上 Infimum 和 Supremum,共 6 條記錄。

這時(shí)候 InnoDB 會(huì)把它們分出 2 個(gè)組:

  • 第一組:只有一個(gè) Infimum 記錄
  • 第二組:剩下的 5 條記錄

每個(gè)槽中,存放著每個(gè)組里最大的那條記錄所在頁面中的地址偏移量。

從圖中,需要關(guān)注頁目錄的一些點(diǎn):

  • 頁目錄有 2 個(gè)槽,說明記錄被分為 2 個(gè)組。
  • Infimum 記錄的 n_owned 屬性值為 1,而 Supremum 的為 5。

為什么這 6 條記錄要這樣分?因?yàn)樽髡邔?duì)于每組中的記錄數(shù)量有規(guī)定:

  • 對(duì)于 Infimum 所在的分組只能有 1 條記錄。
  • Supremum 所在的分組只能在 1~8 條之間。
  • 剩下的分組,記錄條數(shù)范圍只能是 4~8 之間。

三、頁目錄查找記錄的過程

現(xiàn)在繼續(xù)向測(cè)試表里插入 12 條數(shù)據(jù),也就是說在頁中共有 18 條記錄。

然后這些記錄就被分成了 5 個(gè)組,這里參考書籍上的示意圖(只保留一些關(guān)鍵屬性):

現(xiàn)在,要查找主鍵是 6 的記錄,要如何進(jìn)行?

因?yàn)?5 個(gè)槽的編號(hào)分別為 0、1、2、3、4 挨著的,并且里面的主鍵值也都是從小到大進(jìn)行排序的,可以使用二分法(不清楚的可以百度),那么初始情況下 low=0,high=4:

  • 計(jì)算中間槽的位置,(0+4)/ 2=2,于是查看槽 2 對(duì)應(yīng)記錄的主鍵值為 8,因?yàn)?8 > 6,所以 high = 2,low 不變。
  • 重新計(jì)算中間槽位置,(0+2)/ 2=1,于是查看槽 1 對(duì)應(yīng)記錄的主鍵為4,因?yàn)?4 < 6,所以 high 不變,low = 1。
  • 因?yàn)?high - low = 1,所以確定主鍵值為6 的記錄就在槽 2 對(duì)應(yīng)的組中。接著找到該組中主鍵最小的記錄,沿著單鏈表向后遍歷,最終找到主鍵 6 的記錄。

這里有個(gè)問題,槽對(duì)應(yīng)的值都是這個(gè)組的主鍵最大的記錄,如何找到組里最小的記錄?比如槽 2 對(duì)應(yīng)最大主鍵是 8 的記錄,那如何找到最小記錄。

解決辦法是:

  • 通過槽 2 找到 槽 1 對(duì)應(yīng)的記錄,也就是主鍵為 4 的記錄。
  • 主鍵為 4 的記錄的下一條記錄就是槽 2 當(dāng)中主鍵最小的記錄,可以找到主鍵 5。

總結(jié)

在一個(gè)數(shù)據(jù)頁中查找指定主鍵值的記錄,過程分為 2 步:

通過二分法確定該記錄所在分組對(duì)應(yīng)的槽,然后找到該槽所在分組中主鍵值最小的記錄。

通過記錄的 next_record 屬性比那里該槽所在組的各個(gè)記錄,最終找到目標(biāo)記錄。

本文參考書籍: 《mysql是怎樣運(yùn)行的》

以上就是Mysql InnoDB引擎中頁目錄和槽的查找過程的詳細(xì)內(nèi)容,更多關(guān)于Mysql InnoDB引擎頁目錄的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • MySQL?8.0.35數(shù)據(jù)庫下載安裝以及環(huán)境變量的配置方法

    MySQL?8.0.35數(shù)據(jù)庫下載安裝以及環(huán)境變量的配置方法

    很多朋友剛開始接觸mysql數(shù)據(jù)庫服務(wù)器,這篇文章主要給大家介紹了關(guān)于MySQL?8.0.35數(shù)據(jù)庫下載安裝以及環(huán)境變量的配置方法,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-12-12
  • SQL實(shí)現(xiàn)相鄰兩行數(shù)據(jù)的加減乘除操作

    SQL實(shí)現(xiàn)相鄰兩行數(shù)據(jù)的加減乘除操作

    這篇文章主要介紹了SQL實(shí)現(xiàn)相鄰兩行數(shù)據(jù)的加減乘除操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • MySQL索引類型Normal、Unique和Full Text的講解

    MySQL索引類型Normal、Unique和Full Text的講解

    今天小編就為大家分享一篇關(guān)于MySQL索引類型Normal、Unique和Full Text的講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • mysql中json_extract的使用方法實(shí)例詳解

    mysql中json_extract的使用方法實(shí)例詳解

    MYSQl自帶的解析函數(shù)JSON_EXTRACT,用JSON_EXTRACT函數(shù)解析出來的函數(shù)會(huì)包含雙引號(hào),下面這篇文章主要給大家介紹了關(guān)于mysql中json_extract的使用方法,需要的朋友可以參考下
    2023-04-04
  • MySQL的安全問題從安裝開始說起

    MySQL的安全問題從安裝開始說起

    本篇文章小編為大家介紹,關(guān)于MySQL的安全問題從安裝開始說起,有需要的朋友可以參考一下
    2013-04-04
  • MySql字符串拆分實(shí)現(xiàn)split功能(字段分割轉(zhuǎn)列)

    MySql字符串拆分實(shí)現(xiàn)split功能(字段分割轉(zhuǎn)列)

    本文主要介紹了MySql字符串拆分實(shí)現(xiàn)split功能(字段分割轉(zhuǎn)列),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • mysql字段名和關(guān)鍵字沖突的問題

    mysql字段名和關(guān)鍵字沖突的問題

    這篇文章主要介紹了mysql字段名和關(guān)鍵字沖突的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • wampserver下mysql導(dǎo)入數(shù)據(jù)庫的步驟

    wampserver下mysql導(dǎo)入數(shù)據(jù)庫的步驟

    這篇文章主要介紹了wampserver下mysql導(dǎo)入數(shù)據(jù)庫的步驟,需要的朋友可以參考下
    2016-08-08
  • Linux下徹底卸載mysql詳解

    Linux下徹底卸載mysql詳解

    如何在Linux下徹底的卸載MySQL數(shù)據(jù)庫呢? 下面這篇文章就給大家總結(jié)、整理了一下在Linux平臺(tái)下徹底卸載MySQL的方法。 文中通過圖文及示例代碼介紹的很詳細(xì),相信對(duì)大家的理解和學(xué)習(xí)很有幫助,下面有需要的朋友們來一起學(xué)習(xí)學(xué)習(xí)吧。
    2016-11-11
  • Mysql啟動(dòng)的方式(四種)

    Mysql啟動(dòng)的方式(四種)

    本文給大家介紹四種mysql啟動(dòng)方式,實(shí)用性非常高,感興趣的朋友參考下吧
    2016-04-04

最新評(píng)論