MYSQL數(shù)據(jù)庫引擎 MYISAM和 INNODB區(qū)別

MySQL數(shù)據(jù)庫有多種存儲引擎:比如:MyISAM、InnoDB、MERGE、MEMORY(HEAP)、BDB(BerkeleyDB)、EXAMPLE、FEDERATED、ARCHIVE、CSV、BLACKHOLE等等,最常見的也就是MyISAM和InnoDB了,下面主要講解下MyISAM和InnoDB兩種mysql數(shù)據(jù)庫存儲引擎的區(qū)別

MyISAM引擎是一種非事務(wù)性的引擎,提供高速存儲和檢索,以及全文搜索能力,適合數(shù)據(jù)倉庫等查詢頻繁的應(yīng)用。MyISAM中,一個table實(shí)際保存為三個文件,.frm存儲表定義,.MYD存儲數(shù)據(jù),.MYI存儲索引。MyISAM在所有MySQL配置里被支持,它是默認(rèn)的存儲引擎,除非你配置MySQL默認(rèn)使用另外一個引擎。
  MySQL服務(wù)器中的其他非事務(wù)性存儲引擎(如MyISAM)遵從不同的數(shù)據(jù)完整性范例,稱之為“原子操作”。按照事務(wù)術(shù)語,MyISAM表總能高效地工作在AUTOCOMMIT=1模式下。原子操作通常能提供可比較的完整性以及更好的性能。與經(jīng)過優(yōu)化調(diào)整的最快的事務(wù)性表相比,它的速度快3~5倍。由于MySQL服務(wù)器支持兩種范例,因而你能決定是否利用原子操作的速度更好地服務(wù)于你的應(yīng)用程序,或使用事務(wù)特性。該選擇可按表進(jìn)行。
  
  InnoDB則是一種支持事務(wù)的引擎。給MySQL提供了具有提交,回滾和崩潰恢復(fù)能力的事務(wù)安全(ACID兼容)存儲引擎。所以的數(shù)據(jù)存儲在一個或者多個數(shù)據(jù)文件中,支持類似于Oracle的鎖機(jī)制。一般在OLTP應(yīng)用中使用較廣泛。如果沒有指定InnoDB配置選項(xiàng),MySQL將在MySQL數(shù)據(jù)目錄下創(chuàng)建一個名為ibdata1的自動擴(kuò)展數(shù)據(jù)文件,以及兩個名為ib_logfile0和ib_logfile1的日志文件。
  InnoDB鎖定在行級并且也在SELECT語句提供一個Oracle風(fēng)格一致的非鎖定讀。這些特色增加了多用戶部署和性能。沒有在InnoDB中擴(kuò)大鎖定的需要,因?yàn)樵贗nnoDB中行級鎖定適合非常小的空間。InnoDB也支持FOREIGN KEY強(qiáng)制。在SQL查詢中,你可以自由地將InnoDB類型的表與其它MySQL的表的類型混合起來,甚至在同一個查詢中也可以混合。
  InnoDB是為處理巨大數(shù)據(jù)量時的最大性能設(shè)計(jì)。它的CPU效率可能是任何其它基于磁盤的關(guān)系數(shù)據(jù)庫引擎所不能匹敵的。InnoDB存儲引擎被完全與MySQL服務(wù)器整合,InnoDB存儲引擎為在主內(nèi)存中緩存數(shù)據(jù)和索引而維持它自己的緩沖池。
  InnoDB存儲它的表&索引在一個表空間中,表空間可以包含數(shù)個文件。InnoDB表可以是任何尺寸,即使在文件尺寸被限制為2GB的操作系統(tǒng)上。InnoDB也默認(rèn)被包括在所有MySQL 5.1二進(jìn)制分發(fā)版里。

總結(jié)如下:

1、 存儲結(jié)構(gòu)

MyISAM:每個MyISAM在磁盤上存儲成三個文件。第一個文件的名字以表的名字開始,擴(kuò)展名指出文件類型。.frm文件存儲表定義。數(shù)據(jù)文件的擴(kuò)展名為.MYD (MYData)。索引文件的擴(kuò)展名是.MYI (MYIndex)。 InnoDB:所有的表都保存在同一個數(shù)據(jù)文件中(也可能是多個文件,或者是獨(dú)立的表空間文件),InnoDB表的大小只受限于操作系統(tǒng)文件的大小,一般為2GB。

2、 存儲空間

MyISAM:可被壓縮,存儲空間較小。支持三種不同的存儲格式:靜態(tài)表(默認(rèn),但是注意數(shù)據(jù)末尾不能有空格,會被去掉)、動態(tài)表、壓縮表。 InnoDB:需要更多的內(nèi)存和存儲,它會在主內(nèi)存中建立其專用的緩沖池用于高速緩沖數(shù)據(jù)和索引。

3、 事務(wù)支持

MyISAM:強(qiáng)調(diào)的是性能,每次查詢具有原子性,其執(zhí)行數(shù)度比InnoDB類型更快,但是不提供事務(wù)支持。 InnoDB:提供事務(wù)支持事務(wù),外部鍵等高級數(shù)據(jù)庫功能。 具有事務(wù)(commit)、回滾(rollback)和崩潰修復(fù)能力(crash recovery capabilities)的事務(wù)安全(transaction-safe (ACID compliant))型表。

4、 CURD操作

MyISAM:如果執(zhí)行大量的SELECT,MyISAM是更好的選擇。(因?yàn)闆]有支持行級鎖),在增刪的時候需要鎖定整個表格,效率會低一些。相關(guān)的是innodb支持行級鎖,刪除插入的時候只需要鎖定改行就行,效率較高 InnoDB:如果你的數(shù)據(jù)執(zhí)行大量的INSERT或UPDATE,出于性能方面的考慮,應(yīng)該使用InnoDB表。DELETE 從性能上InnoDB更優(yōu),但DELETE FROM table時,InnoDB不會重新建立表,而是一行一行的刪除,在innodb上如果要清空保存有大量數(shù)據(jù)的表,最好使用truncate table這個命令。

5、 外鍵

MyISAM:不支持 InnoDB:支持

MySQL數(shù)據(jù)庫類型從InnoDB轉(zhuǎn)換為MyISAM

USE 數(shù)據(jù)庫名;
SHOW TABLES;
ALTER TABLE 表名 ENGINE=MYISAM;

常用修改

修改MySQL數(shù)據(jù)庫引擎為INNODB:
1、首先修改my.ini,在[mysqld]下加上:

default-storage-engine=INNODB

2、用sql語句修改已經(jīng)建成表的引擎:

alter table 待改表明 type=InnoDB;

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容