mysql中engine=innodb和engine=myisam的區別

1/ISAM 

ISAM是一個定義明確且歷經時間考驗的數據表格管理方法,它在設計之時就考慮到數據庫被查詢的次數要遠大於更新的次數。所以,ISAM執行讀取操做的速度很快,並且不佔用大量的內存和存儲資源。ISAM的兩個主要不足之處在於,它不支持事務處理,也不可以容錯:若是你的硬盤崩潰了,那麼數據文件就沒法恢復了。若是你正在把ISAM用在關鍵任務應用程序裏,那就必須常常備份你全部的實時數據,經過其複製特性,MySQL可以支持這樣的備份應用程序。 

2/InnoDB 

它提供了事務控制能力功能,它確保一組命令所有執行成功,或者當任何一個命令出現錯誤時全部命令的結果都被回退,能夠想像在電子銀行中事務控制能力是很是重要的。支持COMMIT、ROLLBACK和其餘事務特性。最新版本的Mysql已經計劃移除對BDB的支持,轉而全力發展InnoDB。 

MyIASM是IASM表的新版本,有以下擴展: 
二進制層次的可移植性。 
NULL列索引。 
對變長行比ISAM表有更少的碎片。 
支持大文件。 
更好的索引壓縮。 
更好的鍵嗎統計分佈。 
更好和更快的auto_increment處理。 

如下是一些細節和具體實現的差異:

1.InnoDB不支持FULLTEXT類型的索引。
2.InnoDB中不保存表的 
具體行數,也就是說,執行select count(*) from 
table時,InnoDB要掃描一遍整個表來計算有多少行,可是MyISAM只要簡單的讀出保存好的行數便可。注意的是,當count(*)語句包含 
where條件時,兩種表的操做是同樣的。
3.對於AUTO_INCREMENT類型的字段,InnoDB中必須包含只有該字段的索引,可是在MyISAM表中,能夠和其餘字段一塊兒創建聯合索引。
4.DELETE 
FROM table時,InnoDB不會從新創建表,而是一行一行的刪除。
5.LOAD TABLE FROM 
MASTER操做對InnoDB是不起做用的,解決方法是首先把InnoDB表改爲MyISAM表,導入數據後再改爲InnoDB表,可是對於使用的額外的InnoDB特性(例如外鍵)的表不適用。

另外,InnoDB表的行鎖也不是絕對的,若是在執行一個SQL語句時MySQL不能肯定要掃描的範圍,InnoDB表一樣會鎖全表,例如update 
table set num=1 where name like 「�a%」

任何一種表都不是萬能的,只用恰當的針對業務類型來選擇合適的表類型,才能最大的發揮MySQL的性能優點.

MySQL 
Administrator建數據庫的時候,表缺省是InnoDB類型。

InnoDB,MyISAM 
兩種類型有什麼區別:MyISAM類型不支持事務處理等高級處理,而InnoDB類型支持。 
MyISAM類型的表強調的是性能,其執行數度比InnoDB類型更快,可是不提供事務支持,而InnoDB提供事務支持,外鍵等高級數據庫功能。

MyISAM類型的二進制數據文件能夠在不一樣操做系統中遷移。也就是能夠直接從Windows系統拷貝到linux系統中使用。

修改表的引擎類型:

ALTER 
TABLE tablename ENGINE = MyISAM ;

MyISAM:,它是基於傳統的ISAM類型,ISAM是Indexed 
Sequential Access Method (有索引的 順序訪問方法) 
的縮寫,它是存儲記錄和文件的標準方法.與其餘存儲引擎比較,MyISAM具備檢查和修復表格的大多數工具. 
MyISAM表格能夠被壓縮,並且它們支持全文搜索.它們不是事務安全的,並且也不支持外鍵。若是事物回滾將形成不徹底回滾,不具備原子性。若是執行大量 
的SELECT,MyISAM是更好的選擇。

InnoDB:這種類型是事務安全的.它與BDB類型具備相同的特性,它們還支持外鍵.InnoDB表格速度很快.具備比BDB還豐富的特性,所以若是須要一個事務安全的存儲引擎,建議使用它.若是你的數據執行大量的INSERT或UPDATE,出於性能方面的考慮,應該使用InnoDB表,

對於支持事物的InnoDB類型的標,影響速度的主要緣由是AUTOCOMMIT默認設置是打開的,並且程序沒有顯式調用BEGIN 
開始事務,致使每插入一條都自動Commit,嚴重影響了速度。能夠在執行sql前調用begin,多條sql造成一個事物(即便autocommit打 
開也能夠),將大大提升性能。

1.查看錶信息,裏面包括使用的引擎類型,字符編碼,表結構等

使用這個命令

mysql> 
show create table t1;--t1是表名

2. 
能夠執行如下命令來切換非事務表到事務(數據不會丟失),innodb表比myisam表更安全:
alter table t1 
type=innodb;--t1是表名

3. 
innodb表不能用repair table命令和myisamchk -r table_name
但能夠用check table 
t1,以及mysqlcheck [OPTIONS] database [tables]

4. 
啓動mysql數據庫的命令行中添加了如下參數可使新發布的mysql數據表都默認爲使用事務(
隻影響到create語句。)
--default-table-type=InnoDB

5. 
臨時改變默認表類型能夠用:
set table_type=InnoDB;php

MyISAM
優勢:速度快,磁盤空間佔用少;某個庫或表的磁盤佔用狀況既能夠經過操做系統查相應的文件(夾)的大小得知,也能夠經過SQL語句SHOW TABLE STATUS查得
缺點:沒有數據完整性機制,即不支持事務和外鍵

InnoDB
優勢:支持事務和外鍵,數據完整性機制比較完備;能夠用SHOW TABLE STATUS查得某個庫或表的磁盤佔用
缺點:速度超慢,磁盤空間佔用多;全部庫都存於一個(一般狀況)或數個文件中,沒法經過操做系統瞭解某個庫或表的佔用空間

BDB
優勢:支持事務,不支持外鍵,因爲在事務支持的基礎上,外鍵能夠在數據庫的客戶端(多是最終客戶的服務器端,例如php)間接實現,因此數據完整性仍然是有保障的;
缺點:速度慢,磁盤佔用多;不能經過SHOW TABLE STATUS查詢某個庫或表的空間佔用;用操做系統可瞭解庫相應的文件夾,或表相應的文件的大小,但因爲BDB表老是還要產生log文件,而實際的磁盤佔用應該把log文件也包含在內,因此用操做系統查得某庫或表的大小老是小於實際佔用空間。mysql

相關文章
相關標籤/搜索