1. 程式人生 > >MySQL數據庫的幾種引擎

MySQL數據庫的幾種引擎

分析 得到 tab 創建表 陌生 速度 選擇 不同類 無效

有些東西其實一直在用,但是突然問起來它是啥,可能你會很陌生,很陌生,很陌生 .......

mysql的四種引擎

1.MyISAM存儲引擎

不支持事務,不支持外鍵,優勢是訪問速度快,對事務完整性沒有要求或者以select、insert為主的應用基本可以使用該引擎來創建表。
支持三種不同的存儲格式,靜態表,動態表,壓縮表
靜態表:表中的字段都是非變長字段,這樣每個記錄都是固定長度的,優點存儲非常迅速,容易緩存,出現故障容易恢復;缺點是占用的空間比動態表多,因為存儲的時候會按照列的寬度定義補足空格,取數據的時候,默認會把字段後面的空格去掉,如果不註意會把數據本身帶的空格也會忽略。
動態表:記錄不是固定長度,這樣存儲的有點是占用的空間相對較少,缺點,頻繁的更新,刪除數據容易產生碎片,需要定期執行OPTIMIZE TABLE 或者myisamchk -r 命令來改善性能。


壓縮表:因為每個記錄是被單獨壓縮的,所以只有非常小的訪問開支

2.InnoDB存儲引擎

該存儲引擎提供了具有提交,回滾和崩潰恢復能力的事務安全,但是對比MyISAM引擎,寫的處理效率會差一些,並且會占用更多的磁盤空間以保留數據和索引。
InnoDB存儲引擎的特點:支持自動增長列,支持外鍵約束

3.MEMORY存儲引擎

MEMORY存儲引擎使用存在於內存中的內容來創建表,每個memory表只實際對應一個磁盤文件,格式是.frm。 memory類型的表訪問非MEMORY存儲引擎的表可以選擇使用BTREE索引或者HASH索引,兩種不同類型的索引有其不同的使用範圍

hash索引的優點:
hash索引結構的特殊性,其檢索效率非常高,索引的檢索可以一次定位,不像B-Tree索引需要從根節點到枝節點,最後才能訪問到葉節點這樣的多次IO訪問,所以Hash索引的查詢效率要遠高於B-Tree索引。


Hash索引缺點:hash算法是基於等值計算的,所以對於像like這樣的不精確的範圍查找是無效的,即不支持

MEMORY類型的存儲引擎主要用於那些變化不頻繁的代碼表,或者作為統計操作的中間結果表,便於高效地對中間結果進行分析並得到最終的統計結果,對存儲引擎是memory的表進行更新操作要謹慎,因為數據並沒有實際寫入到磁盤中,所以一定要對下次重新啟動服務後如何獲取這些修改後的數據有所考慮。

4.MERGE存儲引擎

Merge存儲引擎是一組MyISAM表的組合,這些MyIASM表必須結構完全相同,merge表本身沒有數據,對merge類型的表可以進行查詢,更新,刪除操作,這些操作實際上是對內部的MyIASM表進行的。

願現實對你溫柔以待,願你的純真長久不熄

MySQL數據庫的幾種引擎