您好,登錄后才能下訂單哦!
MySQL中有哪些存儲引擎,相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
一、引言
在mysql5之后,支持的存儲引擎有十幾個,但是常用的就那么幾種,而且默認支持的也是InnoDB,既然要進行一個對比,我們就要從不同的維度來看一下。
我們可以使用命令來看看當前數(shù)據(jù)庫可以支持的存儲引擎有哪些。
在這里我們發(fā)現(xiàn)默認支持了9種。還是比較多的,下面我們進行一個對比。
不同的存儲引擎都有各自的特點,以適應不同的需求,如表所示。為了做出選擇,首先要考慮每一個存儲引擎提供了哪些不同的功能。
在這里我們列舉了一些特點并作出了比較。下面我們來具體分析對比一下。
1、MyISAM
使用這個存儲引擎,每個MyISAM在磁盤上存儲成三個文件。
(1)frm文件:存儲表的定義數(shù)據(jù)
(2)MYD文件:存放表具體記錄的數(shù)據(jù)
(3)MYI文件:存儲索引
frm和MYI可以存放在不同的目錄下。MYI文件用來存儲索引,但僅保存記錄所在頁的指針,索引的結構是B+樹結構。下面這張圖就是MYI文件保存的機制:
從這張圖可以發(fā)現(xiàn),這個存儲引擎通過MYI的B+樹結構來查找記錄頁,再根據(jù)記錄頁查找記錄。并且支持全文索引、B樹索引和數(shù)據(jù)壓縮。
支持數(shù)據(jù)的類型也有三種:
(1)靜態(tài)固定長度表
這種方式的優(yōu)點在于存儲速度非???,容易發(fā)生緩存,而且表發(fā)生損壞后也容易修復。缺點是占空間。這也是默認的存儲格式。
(2)動態(tài)可變長表
優(yōu)點是節(jié)省空間,但是一旦出錯恢復起來比較麻煩。
(3)壓縮表
上面說到支持數(shù)據(jù)壓縮,說明肯定也支持這個格式。在數(shù)據(jù)文件發(fā)生錯誤時候,可以使用check table工具來檢查,而且還可以使用repair table工具來恢復。
有一個重要的特點那就是不支持事務,但是這也意味著他的存儲速度更快,如果你的讀寫操作允許有錯誤數(shù)據(jù)的話,只是追求速度,可以選擇這個存儲引擎。
2、InnoDB
InnoDB是默認的數(shù)據(jù)庫存儲引擎,他的主要特點有:
(1)可以通過自動增長列,方法是auto_increment。
(2)支持事務。默認的事務隔離級別為可重復度,通過MVCC(并發(fā)版本控制)來實現(xiàn)的。
(3)使用的鎖粒度為行級鎖,可以支持更高的并發(fā);
(4)支持外鍵約束;外鍵約束其實降低了表的查詢速度,但是增加了表之間的耦合度。
(5)配合一些熱備工具可以支持在線熱備份;
(6)在InnoDB中存在著緩沖管理,通過緩沖池,將索引和數(shù)據(jù)全部緩存起來,加快查詢的速度;
(7)對于InnoDB類型的表,其數(shù)據(jù)的物理組織形式是聚簇表。所有的數(shù)據(jù)按照主鍵來組織。數(shù)據(jù)和索引放在一塊,都位于B+數(shù)的葉子節(jié)點上;
當然InnoDB的存儲表和索引也有下面兩種形式:
(1)使用共享表空間存儲:所有的表和索引存放在同一個表空間中。
(2)使用多表空間存儲:表結構放在frm文件,數(shù)據(jù)和索引放在IBD文件中。分區(qū)表的話,每個分區(qū)對應單獨的IBD文件,分區(qū)表的定義可以查看我的其他文章。使用分區(qū)表的好處在于提升查詢效率。
對于InnoDB來說,比較大的特點在于支持事務。但是這是以損失效率來換取的。
3、Memory
將數(shù)據(jù)存在內(nèi)存,為了提高數(shù)據(jù)的訪問速度,每一個表實際上和一個磁盤文件關聯(lián)。文件是frm。
(1)支持的數(shù)據(jù)類型有限制,比如:不支持TEXT和BLOB類型,對于字符串類型的數(shù)據(jù),只支持固定長度的行,VARCHAR會被自動存儲為CHAR類型;
(2)支持的鎖粒度為表級鎖。所以,在訪問量比較大時,表級鎖會成為MEMORY存儲引擎的瓶頸;
(3)由于數(shù)據(jù)是存放在內(nèi)存中,一旦服務器出現(xiàn)故障,數(shù)據(jù)都會丟失;
(4)查詢的時候,如果有用到臨時表,而且臨時表中有BLOB,TEXT類型的字段,那么這個臨時表就會轉化為MyISAM類型的表,性能會急劇降低;
(5)默認使用hash索引。
(6)如果一個內(nèi)部表很大,會轉化為磁盤表。
在這里只是給出3個常見的存儲引擎。使用哪一種引擎需要靈活選擇,一個數(shù)據(jù)庫中多個表可以使用不同引擎以滿足各種性能和實際需求,使用合適的存儲引擎,將會提高整個數(shù)據(jù)庫的性能
看完上述內(nèi)容,你們掌握MySQL中有哪些存儲引擎的方法了嗎?如果還想學到更多技能或想了解更多相關內(nèi)容,歡迎關注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。