基礎(chǔ)知識(shí)
在關(guān)系型數(shù)據(jù)庫(kù)中每一個(gè)數(shù)據(jù)表相當(dāng)于一個(gè)文件,而不同的存儲(chǔ)引擎則會(huì)構(gòu)建出不同的表類型。
存儲(chǔ)引擎的作用是規(guī)定數(shù)據(jù)表如何存儲(chǔ)數(shù)據(jù),如何為存儲(chǔ)的數(shù)據(jù)建立索引以及如何支持更新、查詢等技術(shù)的實(shí)現(xiàn)。
在Oracle以及SqlServer等數(shù)據(jù)庫(kù)中只支持一種存儲(chǔ)引擎,故其數(shù)據(jù)存儲(chǔ)管理機(jī)制都是一樣的,而MySQL中提供了多種存儲(chǔ)引擎,用戶可以根據(jù)不同的需求為數(shù)據(jù)表選擇不同的存儲(chǔ)引擎,用戶也可以根據(jù)自己的需要編寫(xiě)自己的存儲(chǔ)引擎。
如處理文本文件可使用txt類型,處理圖片可使用png類型
存儲(chǔ)引擎
在MySQL中支持多種存儲(chǔ)引擎,使用show engines
;命令可查看所支持的存儲(chǔ)引擎
mysql> show engines;
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| Engine | Support | Comment | Transactions | XA | Savepoints |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| InnoDB | DEFAULT | Supports transactions, row-level locking, and foreign keys | YES | YES | YES |
| MRG_MYISAM | YES | Collection of identical MyISAM tables | NO | NO | NO |
| MEMORY | YES | Hash based, stored in memory, useful for temporary tables | NO | NO | NO |
| BLACKHOLE | YES | /dev/null storage engine (anything you write to it disappears) | NO | NO | NO |
| MyISAM | YES | MyISAM storage engine | NO | NO | NO |
| CSV | YES | CSV storage engine | NO | NO | NO |
| ARCHIVE | YES | Archive storage engine | NO | NO | NO |
| PERFORMANCE_SCHEMA | YES | Performance Schema | NO | NO | NO |
| FEDERATED | NO | Federated MySQL storage engine | NULL | NULL | NULL |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
9 rows in set (0.00 sec)
mysql>
InnoDB
InnoDB存儲(chǔ)引擎是MySQL默認(rèn)的存儲(chǔ)引擎,支持事務(wù)操作,其設(shè)計(jì)目標(biāo)主要面向聯(lián)機(jī)事務(wù)處理(OLTP)的應(yīng)用。
特點(diǎn)是行鎖設(shè)計(jì)、支持外鍵,并支持類似Oracle的非鎖定讀,即默認(rèn)讀取操作不會(huì)產(chǎn)生鎖。 InnoDB存儲(chǔ)引擎將數(shù)據(jù)放在一個(gè)邏輯的表空間中,這個(gè)表空間就像黑盒一樣由InnoDB存儲(chǔ)引擎自身來(lái)管理。
從MySQL4.1(包括 4.1)版本開(kāi)始,可以將每個(gè)InnoDB存儲(chǔ)引擎的 表單獨(dú)存放到一個(gè)獨(dú)立的 ibd文件中。此外,InnoDB存儲(chǔ)引擎支持將裸設(shè)備(row disk)用 于建立其表空間。 InnoDB通過(guò)使用多版本并發(fā)控制(MVCC)來(lái)獲得高并發(fā)性,并且實(shí)現(xiàn)了SQL標(biāo)準(zhǔn) 的4種隔離級(jí)別,默認(rèn)為REPEATABLE級(jí)別,同時(shí)使用一種稱為netx-key locking的策略來(lái)避免幻讀(phantom)現(xiàn)象的產(chǎn)生。
除此之外,InnoDB存儲(chǔ)引擎還提供了插入緩沖(insert buffer)、二次寫(xiě)(double write)、自適應(yīng)哈希索引(adaptive hash index)、預(yù)讀(read ahead) 等高性能和高可用的功能。 對(duì)于表中數(shù)據(jù)的存儲(chǔ),InnoDB存儲(chǔ)引擎采用了聚集(clustered)的方式,每張表都是按主鍵的順序進(jìn)行存儲(chǔ)的,如果沒(méi)有顯式地在表定義時(shí)指定主鍵,InnoDB存儲(chǔ)引擎會(huì)為每一 行生成一個(gè) 6字節(jié)的行ID(ROWID),并以此作為主鍵。 InnoDB存儲(chǔ)引擎是 MySQL數(shù)據(jù)庫(kù)最為常用的一種引擎,F(xiàn)acebook、Google、Yahoo等 公司的成功應(yīng)用已經(jīng)證明了 InnoDB存儲(chǔ)引擎具備高可用性、高性能以及高可擴(kuò)展性。對(duì)其底層實(shí)現(xiàn)的掌握和理解也需要時(shí)間和技術(shù)的積累。
如果想深入了解 InnoDB存儲(chǔ)引擎的工作原理、實(shí)現(xiàn)和應(yīng)用可以參考《MySQL 技術(shù)內(nèi)幕:InnoDB存儲(chǔ)引擎》一書(shū)。
MyISAM
不支持事務(wù)、表鎖設(shè)計(jì)、支持全文索引,主要面向一些 OLAP數(shù)據(jù)庫(kù)應(yīng)用,在MySQL5.5.8版本之前是默認(rèn)的存儲(chǔ)引擎(除 Windows 版本外)。數(shù)據(jù)庫(kù)系統(tǒng)與文件系統(tǒng)一個(gè)很大的不同在于對(duì)事務(wù)的支持,MyISAM存儲(chǔ)引擎是不支持事務(wù)的。
究其根本,這也并不難理解。用戶在所有的應(yīng)用中是否都需要事務(wù)呢?在數(shù)據(jù)倉(cāng)庫(kù)中,如果沒(méi)有ETL這些操作,只是簡(jiǎn)單地通過(guò)報(bào)表查詢還需要事務(wù)的支持嗎?此外,MyISAM存儲(chǔ)引擎的另一個(gè)與眾不同的地方是,它的緩沖池只緩存(cache)索引文件,而不緩存數(shù)據(jù)文件,這與大多數(shù)的數(shù)據(jù)庫(kù)都不相同。
NDB
2003年,MysqlAB公司從SonyEricsson公司收購(gòu)了NDB存儲(chǔ)引擎。
NDB存儲(chǔ)引擎是一個(gè)集群存儲(chǔ)引擎,類似于Oracle的RAC集群,不過(guò)與Oracle RAC的share everythin結(jié)構(gòu)不同的是,其結(jié)構(gòu)是share nothing的集群架構(gòu),因此能提供更高級(jí)別的高可用性。
NDB存儲(chǔ)引擎的特點(diǎn)是數(shù)據(jù)全部放在內(nèi)存中(從 5.1 版本開(kāi)始,可以將非索引數(shù)據(jù)放在磁盤(pán)上),因此主鍵查找(primary key lookups)的速度極快,并且能夠在線添加 NDB數(shù)據(jù)存儲(chǔ)節(jié)點(diǎn)(data node)以便線性地提高數(shù)據(jù)庫(kù)性能。
由此可見(jiàn),NDB存儲(chǔ)引擎是高可用、 高性能、高可擴(kuò)展性的數(shù)據(jù)庫(kù)集群系統(tǒng),其面向的也是OLTP的數(shù)據(jù)庫(kù)應(yīng)用類型。
Memory
正如其名,Memory存儲(chǔ)引擎中的數(shù)據(jù)都存放在內(nèi)存中。
數(shù)據(jù)庫(kù)重啟或發(fā)生崩潰,表中的數(shù)據(jù)都將消失。它非常適合于存儲(chǔ)OLTP數(shù)據(jù)庫(kù)應(yīng)用中臨時(shí)數(shù)據(jù)的臨時(shí)表,也可以作為OLAP數(shù)據(jù)庫(kù)應(yīng)用中數(shù)據(jù)倉(cāng)庫(kù)的維度表。
Memory存儲(chǔ)引擎默認(rèn)使用哈希索引,而不是通常熟悉的B+樹(shù)索引。
Infobright
第三方的存儲(chǔ)引擎。
其特點(diǎn)是存儲(chǔ)是按照列而非行的,因此非常適合OLAP的數(shù)據(jù)庫(kù)應(yīng)用。
其官方網(wǎng)站是 http://www.infobright.org/,上面有不少成功的數(shù)據(jù) 倉(cāng)庫(kù)案例可供分析。
NTSE
網(wǎng)易公司開(kāi)發(fā)的面向其內(nèi)部使用的存儲(chǔ)引擎。
目前的版本不支持事務(wù),但提供壓縮、行級(jí)緩存等特性,不久的將來(lái)會(huì)實(shí)現(xiàn)面向內(nèi)存的事務(wù)支持。
BLACKHOLE
洞存儲(chǔ)引擎,可以應(yīng)用于主備復(fù)制中的分發(fā)主庫(kù)。
配置引擎
建表指定
在建表語(yǔ)句后使用engine
關(guān)鍵字可指定存儲(chǔ)引擎。
create table 表名(id int,name char) engine=存儲(chǔ)引擎(默認(rèn)innodb);
以下將創(chuàng)建一個(gè)temp臨時(shí)表,使用memory存儲(chǔ)引擎。
mysql> create table temp(id int) engine=memory;
Query OK, 0 rows affected (0.01 sec)
mysql> show create table temp; # 查看創(chuàng)建信息
+-------+------------------------------------------------------------------------------------------+
| Table | Create Table |
+-------+------------------------------------------------------------------------------------------+
| temp | CREATE TABLE `temp` (
`id` int(11) DEFAULT NULL
) ENGINE=MEMORY DEFAULT CHARSET=latin1 |
+-------+------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
mysql>
memory中的數(shù)據(jù)將在關(guān)閉MySQL服務(wù)時(shí)清空。
而blackhole存儲(chǔ)引擎特征則是無(wú)論插入多少條記錄表內(nèi)永遠(yuǎn)都不會(huì)存放。
配置指定
在配置文件中,也可指定建表時(shí)的存儲(chǔ)引擎。
[mysqld]
#創(chuàng)建新表時(shí)將使用的默認(rèn)存儲(chǔ)引擎
default-storage-engine=INNODB
文件結(jié)構(gòu)
這里以InnoDB為例,我們先創(chuàng)建出一個(gè)student表,再查看其文件結(jié)構(gòu)。
mysql> create table student(id int) engine=innodb;
Query OK, 0 rows affected (0.02 sec)

student.frm 存儲(chǔ)的是表結(jié)構(gòu),如字段等信息
student.ibd 存儲(chǔ)的是表數(shù)據(jù),如記錄等信息
以上就是聊聊MySQL中的存儲(chǔ)引擎的詳細(xì)內(nèi)容,更多關(guān)于MySQL 存儲(chǔ)引擎的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
您可能感興趣的文章:- SQL Server中的執(zhí)行引擎入門(mén) 圖解
- MySQL 常見(jiàn)存儲(chǔ)引擎的優(yōu)劣
- 修改MySQL數(shù)據(jù)庫(kù)引擎為InnoDB的操作
- 關(guān)于MySQL Memory存儲(chǔ)引擎的相關(guān)知識(shí)
- 詳解mysql中的存儲(chǔ)引擎
- MySQL 選擇合適的存儲(chǔ)引擎
- MySQL創(chuàng)建數(shù)據(jù)表時(shí)設(shè)定引擎MyISAM/InnoDB操作
- 簡(jiǎn)述MySQL InnoDB存儲(chǔ)引擎
- 如何自己動(dòng)手寫(xiě)SQL執(zhí)行引擎