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;
MyISAM
優點:速度快,磁盤空間占用少;某個庫或表的磁盤占用情況既可以通過操作系統查相應的文件(夾)的大小得知,也可以通過SQL語句SHOW TABLE STATUS查得
缺點:沒有數據完整性機制,即不支持事務和外鍵
InnoDB
優點:支持事務和外鍵,數據完整性機制比較完備;可以用SHOW TABLE STATUS查得某個庫或表的磁盤占用
缺點:速度超慢,磁盤空間占用多;所有庫都存於一個(通常情況)或數個文件中,無法通過操作系統了解某個庫或表的占用空間
BDB
優點:支持事務,不支持外鍵,由於在事務支持的基礎上,外鍵可以在數據庫的客戶端(可能是最終客戶的服務器端,例如php)間接實現,所以數據完整性仍然是有保障的;
缺點:速度慢,磁盤占用多;不能通過SHOW TABLE STATUS查詢某個庫或表的空間占用;用操作系統可了解庫相應的文件夾,或表相應的文件的大小,但由於BDB表總是還要產生log文件,而實際的磁盤占用應該把log文件也包含在內,所以用操作系統查得某庫或表的大小總是小於實際占用空間。