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;
MyISAM
優點:速度快,磁盤空間占用少;某個庫或表的磁盤占用情況既可以通過操作系統查相應的文件(夾)的大小得知,也可以通過SQL語句SHOW TABLE STATUS查得
缺點:沒有數據完整性機制,即不支持事務和外鍵
InnoDB
優點:支持事務和外鍵,數據完整性機制比較完備;可以用SHOW TABLE STATUS查得某個庫或表的磁盤占用
缺點:速度超慢,磁盤空間占用多;所有庫都存于一個(通常情況)或數個文件中,無法通過操作系統了解某個庫或表的占用空間
BDB
優點:支持事務,不支持外鍵,由于在事務支持的基礎上,外鍵可以在數據庫的客戶端(可能是最終客戶的服務器端,例如php)間接實現,所以數據完整性仍然是有保障的;
缺點:速度慢,磁盤占用多;不能通過SHOW TABLE STATUS查詢某個庫或表的空間占用;用操作系統可了解庫相應的文件夾,或表相應的文件的大小,但由于BDB表總是還要產生log文件,而實際的磁盤占用應該把log文件也包含在內,所以用操作系統查得某庫或表的大小總是小于實際占用空間。
轉載于:https://www.cnblogs.com/focusxxxxy/p/6388820.html
總結
以上是生活随笔為你收集整理的mysql中engine=innodb和engine=myisam的区别的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 了解iphone的特色传感器
- 下一篇: iPhone6 和iPhone6plus