在MySQL中,索引是一種用于優(yōu)化查詢的數(shù)據(jù)結(jié)構(gòu)。其中,普通索引是最常用的索引類型之一,它能夠幫助數(shù)據(jù)庫(kù)更快速地定位數(shù)據(jù)。普通索引又分為B樹索引和哈希索引兩種。那么,不同類型的普通索引存放了哪些數(shù)據(jù)呢?下面我們就來(lái)一探究竟。
首先,我們來(lái)看B樹索引。B樹索引通過(guò)構(gòu)建一棵類似于二叉樹的樹形結(jié)構(gòu)來(lái)存儲(chǔ)索引數(shù)據(jù)。在B樹索引中,每個(gè)節(jié)點(diǎn)都會(huì)存儲(chǔ)一個(gè)索引值和對(duì)應(yīng)的指針,這個(gè)指針可以指向葉子節(jié)點(diǎn),也可以指向下一層的中間節(jié)點(diǎn)。因此,在B樹索引中,每個(gè)節(jié)點(diǎn)所存儲(chǔ)的數(shù)據(jù)包括:索引值和指針。
CREATE TABLE mytable ( id INT PRIMARY KEY, name VARCHAR(50) ); CREATE INDEX idx_name ON mytable (name);
接下來(lái),讓我們看看哈希索引。哈希索引采用哈希表的數(shù)據(jù)結(jié)構(gòu)來(lái)存儲(chǔ)索引數(shù)據(jù),它通過(guò)對(duì)索引值進(jìn)行哈希運(yùn)算來(lái)獲取數(shù)據(jù)存取的位置。在哈希索引中,每個(gè)鍵值對(duì)都會(huì)被存儲(chǔ)在哈希表中的特定位置。因此,在哈希索引中,每個(gè)鍵值對(duì)所存儲(chǔ)的數(shù)據(jù)包括:索引值和對(duì)應(yīng)的數(shù)據(jù)存儲(chǔ)位置。
CREATE TABLE mytable ( id INT PRIMARY KEY, name VARCHAR(50) ); CREATE HASH INDEX idx_name ON mytable (name);
綜上所述,不同類型的普通索引存儲(chǔ)的數(shù)據(jù)有所不同。B樹索引存儲(chǔ)的是索引值和指針,而哈希索引存儲(chǔ)的是索引值和對(duì)應(yīng)的數(shù)據(jù)存儲(chǔ)位置。