MySQL MyISAM默認(rèn)存儲(chǔ)引擎實(shí)現(xiàn)原理
默認(rèn)MyISAM的表會(huì)在磁盤中產(chǎn)生3個(gè)文件:.frm(表結(jié)構(gòu)文件)、.MYD(數(shù)據(jù)文件)、.MYI(索引文件)
可以在創(chuàng)建的時(shí)候指定數(shù)據(jù)文件和索引文件的存儲(chǔ)位置,只有MyISAM表支持:
DATA DIRECTORY [=] 數(shù)據(jù)保存的絕對(duì)路徑 INDEX DIRECTORY [=] 索引文件的絕對(duì)路徑MyISAM單表最大支持的數(shù)據(jù)量為2的64次方跳記錄
每個(gè)表最多可以建立64個(gè)索引
如果是復(fù)合索引,每個(gè)復(fù)合索引最多包含16個(gè)列,索引值最大長度是1000B
MyISAM引擎的存儲(chǔ)格式:
定長(FIXED 靜態(tài)) :是指字段不包含VARCHAR/TEXT/BLOB 動(dòng)態(tài)(DYNAMIC) :只要字段中包含了VARCHAR/TEXT/BLOB 壓縮(COMPRESSED):muisampack創(chuàng)建InnoDB存儲(chǔ)引擎:
設(shè)計(jì)遵循ACID模型,支持事務(wù),具有從服務(wù)崩潰中恢復(fù)的能力,能夠最大限度保護(hù)用戶的數(shù)據(jù)
支持行級(jí)鎖,可以提升多用戶并發(fā)時(shí)的讀寫性能
InnoDB擁有自己獨(dú)立的緩沖池,常用的數(shù)據(jù)和索引都在緩存中
對(duì)于INSERT、UPDATE、DELETE操作,InnoDB會(huì)使用一種change buffering的機(jī)制來自動(dòng)優(yōu)化,還可以提供一致性的讀,并且還能夠緩存變更的數(shù)據(jù),減少磁盤I/O,提高性能
創(chuàng)建InnoDB表之后會(huì)產(chǎn)生兩個(gè)文件:
.frm表結(jié)構(gòu)文件 .ibd 數(shù)據(jù)和索引存儲(chǔ)表空間中所有的表都需要?jiǎng)?chuàng)建主鍵,最好是配合上AUTO_INCREMENT,也可以放到經(jīng)常查詢的列作為主鍵
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 關(guān)于Oracle數(shù)據(jù)庫熱備份腳本深入剖析2. 一文帶你了解MySQL的左連接與右連接3. Access數(shù)據(jù)庫安全的幾個(gè)問題4. ORACLE中如何實(shí)現(xiàn)ASCII字符串和16進(jìn)制串互相轉(zhuǎn)換5. mysql-bin.000001文件的來源及處理方法6. Sql server數(shù)據(jù)庫開發(fā)常用匯總7. MySQL雙主(主主)架構(gòu)配置方案8. 如何遠(yuǎn)程調(diào)用ACCESS數(shù)據(jù)庫9. MySQL 的啟動(dòng)選項(xiàng)和系統(tǒng)變量實(shí)例詳解10. MySQL存儲(chǔ)過程例子(包含事務(wù)、參數(shù)、嵌套調(diào)用、游標(biāo)循環(huán)等)
