全國(guó)咨詢(xún)/投訴熱線(xiàn):400-618-4000

首頁(yè)技術(shù)文章正文

MySQL數(shù)據(jù)庫(kù)存儲(chǔ)引擎【InnoDB/MyISAM/MEMORY 】

更新時(shí)間:2022-07-25 來(lái)源:黑馬程序員 瀏覽量:

IT培訓(xùn)班

1.InnoDB存儲(chǔ)引擎

InnoDB給MySQL的表提供了事務(wù)處理、回滾、崩潰修復(fù)能力和多版本并發(fā)控制的事務(wù)安全。在MySQL從3.23.34a開(kāi)始包含InnnoDB。它是MySQL上第一個(gè)提供外鍵約束的表引擎。而且InnoDB對(duì)事務(wù)處理的能力,也是其他存儲(chǔ)引擎不能比擬的。靠后版本的MySQL的默認(rèn)存儲(chǔ)引擎就是InnoDB。

InnoDB存儲(chǔ)引擎總支持AUTO_INCREMENT。自動(dòng)增長(zhǎng)列的值不能為空,并且值必須唯一。MySQL中規(guī)定自增列必須為主鍵。在插入值的時(shí)候,如果自動(dòng)增長(zhǎng)列不輸入值,則插入的值為自動(dòng)增長(zhǎng)后的值;如果輸入的值為0或空(NULL),則插入的值也是自動(dòng)增長(zhǎng)后的值;如果插入某個(gè)確定的值,且該值在前面沒(méi)有出現(xiàn)過(guò),就可以直接插入。

InnoDB還支持外鍵(FOREIGN KEY)。外鍵所在的表叫做子表,外鍵所依賴(lài)(REFERENCES)的表叫做父表。父表中被字表外鍵關(guān)聯(lián)的字段必須為主鍵。當(dāng)刪除、更新父表中的某條信息時(shí),子表也必須有相應(yīng)的改變,這是數(shù)據(jù)庫(kù)的參照完整性規(guī)則。

InnoDB中,創(chuàng)建的表的表結(jié)構(gòu)存儲(chǔ)在.frm文件中(我覺(jué)得是frame的縮寫(xiě)吧)。數(shù)據(jù)和索引存儲(chǔ)在innodb_data_home_dirinnodb_data_file_path定義的表空間中。

InnoDB的優(yōu)勢(shì)在于提供了良好的事務(wù)處理、崩潰修復(fù)能力和并發(fā)控制。缺點(diǎn)是讀寫(xiě)效率較差,占用的數(shù)據(jù)空間相對(duì)較大。

2.MyISAM存儲(chǔ)引擎

MyISAM是MySQL中常見(jiàn)的存儲(chǔ)引擎,曾經(jīng)是MySQL的默認(rèn)存儲(chǔ)引擎。MyISAM是基于ISAM引擎發(fā)展起來(lái)的,增加了許多有用的擴(kuò)展。

MyISAM的表存儲(chǔ)成3個(gè)文件。文件的名字與表名相同。拓展名為frm、MYD、MYI。其實(shí),frm文件存儲(chǔ)表的結(jié)構(gòu);MYD文件存儲(chǔ)數(shù)據(jù),是MYData的縮寫(xiě);MYI文件存儲(chǔ)索引,是MYIndex的縮寫(xiě)。

基于MyISAM存儲(chǔ)引擎的表支持3種不同的存儲(chǔ)格式。包括靜態(tài)型、動(dòng)態(tài)型和壓縮型。其中,靜態(tài)型是MyISAM的默認(rèn)存儲(chǔ)格式,它的字段是固定長(zhǎng)度的;動(dòng)態(tài)型包含變長(zhǎng)字段,記錄的長(zhǎng)度不是固定的;壓縮型需要用到myisampack工具,占用的磁盤(pán)空間較小。

MyISAM的優(yōu)勢(shì)在于占用空間小,處理速度快。缺點(diǎn)是不支持事務(wù)的完整性和并發(fā)性。

MySQL數(shù)據(jù)庫(kù)

3.MEMORY存儲(chǔ)引擎

MEMORY是MySQL中一類(lèi)特殊的存儲(chǔ)引擎。它使用存儲(chǔ)在內(nèi)存中的內(nèi)容來(lái)創(chuàng)建表,而且數(shù)據(jù)全部放在內(nèi)存中。這些特性與前面的兩個(gè)很不同。

每個(gè)基于MEMORY存儲(chǔ)引擎的表實(shí)際對(duì)應(yīng)一個(gè)磁盤(pán)文件。該文件的文件名與表名相同,類(lèi)型為frm類(lèi)型。該文件中只存儲(chǔ)表的結(jié)構(gòu)。而其數(shù)據(jù)文件,都是存儲(chǔ)在內(nèi)存中,這樣有利于數(shù)據(jù)的快速處理,提高整個(gè)表的效率。值得注意的是,服務(wù)器需要有足夠的內(nèi)存來(lái)維持MEMORY存儲(chǔ)引擎的表的使用。如果不需要了,可以釋放內(nèi)存,甚至刪除不需要的表。

MEMORY默認(rèn)使用哈希索引。速度比使用B型樹(shù)索引快。當(dāng)然如果你想用B型樹(shù)索引,可以在創(chuàng)建索引時(shí)指定。

注意,MEMORY用到的很少,因?yàn)樗前褦?shù)據(jù)存到內(nèi)存中,如果內(nèi)存出現(xiàn)異常就會(huì)影響數(shù)據(jù)。如果重啟或者關(guān)機(jī),所有數(shù)據(jù)都會(huì)消失。因此,基于MEMORY的表的生命周期很短,一般是一次性的。

分享到:
在線(xiàn)咨詢(xún) 我要報(bào)名
和我們?cè)诰€(xiàn)交談!