數(shù)據(jù)頁
在數(shù)據(jù)庫中,數(shù)據(jù)頁是用于存儲(chǔ)數(shù)據(jù)的基本單位。它是一個(gè)固定大小的內(nèi)存塊或磁盤塊,用于存儲(chǔ)數(shù)據(jù)庫中的數(shù)據(jù)記錄。數(shù)據(jù)頁通常包含多條數(shù)據(jù)記錄,這些記錄可以是表中的行或索引中的鍵值對等。
數(shù)據(jù)頁的大小通常是數(shù)據(jù)庫系統(tǒng)在創(chuàng)建數(shù)據(jù)庫時(shí)設(shè)置的,一般為4KB、8KB或16KB等。數(shù)據(jù)庫系統(tǒng)將數(shù)據(jù)按照頁的大小進(jìn)行劃分和存儲(chǔ),每個(gè)數(shù)據(jù)頁都有一個(gè)唯一的標(biāo)識符或地址,用于在數(shù)據(jù)庫中定位和訪問數(shù)據(jù)。
當(dāng)數(shù)據(jù)庫系統(tǒng)需要讀取或?qū)懭霐?shù)據(jù)時(shí),通常會(huì)以數(shù)據(jù)頁為單位進(jìn)行操作。如果數(shù)據(jù)量比較大,無法一次性將所有數(shù)據(jù)加載到內(nèi)存中,那么數(shù)據(jù)庫系統(tǒng)會(huì)根據(jù)需要從磁盤中讀取或?qū)懭霐?shù)據(jù)頁,這個(gè)過程就是磁盤 I/O 操作。
總的來說,數(shù)據(jù)頁是數(shù)據(jù)庫中存儲(chǔ)數(shù)據(jù)的基本單位,它提供了一種有效的方式來管理和存儲(chǔ)數(shù)據(jù)庫中的數(shù)據(jù)。
葉子節(jié)點(diǎn)頁
在 B+ 樹索引中,葉子節(jié)點(diǎn)頁是 B+ 樹結(jié)構(gòu)中的最底層節(jié)點(diǎn),也是存儲(chǔ)實(shí)際數(shù)據(jù)記錄的節(jié)點(diǎn)。與內(nèi)部節(jié)點(diǎn)不同,葉子節(jié)點(diǎn)頁中存儲(chǔ)的是實(shí)際的數(shù)據(jù)記錄,而不是索引鍵值對。每個(gè)葉子節(jié)點(diǎn)頁通常包含多條數(shù)據(jù)記錄,這些記錄按照鍵值的順序排序。
葉子節(jié)點(diǎn)頁通常通過雙向鏈表連接起來,以支持范圍查詢和排序操作。雙向鏈表使得可以從任意一個(gè)葉子節(jié)點(diǎn)出發(fā),沿著鏈表順序遍歷所有的葉子節(jié)點(diǎn),從而快速獲取滿足查詢條件的數(shù)據(jù)記錄。
在 B+ 樹索引中,葉子節(jié)點(diǎn)頁是查詢操作的終點(diǎn),當(dāng)執(zhí)行查詢操作時(shí),數(shù)據(jù)庫系統(tǒng)會(huì)從根節(jié)點(diǎn)開始逐層下降,直到到達(dá)葉子節(jié)點(diǎn)頁,然后在葉子節(jié)點(diǎn)頁中找到滿足查詢條件的數(shù)據(jù)記錄。因此,葉子節(jié)點(diǎn)頁是 B+ 樹索引中存儲(chǔ)實(shí)際數(shù)據(jù)記錄的重要組成部分。