MySql存儲引擎的選取
存儲引擎是為不同的表類型處理 SQL 操作的 MySql 組件。InnoDB 是默認的、最通用的存儲引擎,也是官方推薦使用的存儲引擎,除非一些特定案例。MySql 5.6 中的 CREATE TABLE 語句創建的表的存儲引擎默認就是 InnoDB。MySql 服務器使用的是一個可插拔存儲引擎架構,它能夠在運行的時候動態加載或者卸載這些存儲引擎。可以使用 SHOW ENGINES 語句來查看你的 MySql 服務器所支持的存儲引擎。Support 列裡的值指示出是否一個引擎可以被你使用:YES、NO 以及 DEFAULT 值分別表示某存儲引擎是可用、不可用、可用並且是當前默認的存儲引擎。
MySql 5.6 所支持的存儲引擎
InnoDB:MySql 5.6 版本默認的存儲引擎。InnoDB 是一個事務安全的存儲引擎,它具備提交、回滾以及崩潰恢復的功能以保護用戶數據。InnoDB 的行級別鎖定以及 Oracle 風格的一致性無鎖讀提升了它的多用戶並發數以及性能。InnoDB 將用戶數據存儲在聚集索引中以減少基於主鍵的普通查詢所帶來的 I/O 開銷。為了保證數據的完整性,InnoDB 還支持外鍵約束。
MyISAM:行級別的鎖定限制了它在讀寫負載方面的性能,因此它經常應用於只讀或者以讀為主的數據場景。
Memory:在內存中存儲所有數據,應用於對非關鍵數據由快速查找的場景。Memory 引擎曾被稱為 HEAP 引擎。它的使用案例正在減少:InnoDB 的內存緩沖區為將大部分或全部數據保持在內存提供了一個通用並耐用的方式,NDBCLUSTER 為大分布式數據集提供了快速的 key-value 訪問。
CSV:它的表真的是以逗號分隔的文本文件。CSV 表允許你以 CSV 格式導入導出數據,以相同的讀和寫的格式和腳本和應用交互數據。由於 CSV 表沒有索引,你最好是在普通操作中將數據放在 InnoDB 表裡,只有在導入或導出階段使用一下 CSV 表。
Archive:黑洞存儲引擎,類似於 Unix 的 /dev/null,Archive 只接收但卻並不保存數據。對這種引擎的表的查詢常常返回一個空集。這種表可以應用於 DML 語句需要發送到從服務器,但主服務器並不會保留這種數據的備份的主從配置中。
NDB:(又名 NDBCLUSTER)——這種集群數據引擎尤其適合於需要最高程度的正常運行時間和可用性的應用。注意:NDB 存儲引擎在標准 MySql 5.6 版本裡並不被支持。目前能夠支持 MySql 集群的版本有:基於 MySql 5.1 的 MySQL Cluster NDB 7.1;基於 MySql 5.5 的 MySQL Cluster NDB 7.2;基於 MySql 5.6 的 MySQL Cluster NDB 7.3。同樣基於 MySql 5.6 的 MySQL Cluster NDB 7.4 目前正處於研發階段。
Merge:允許 MySql DBA 或開發者將一系列相同的 MyISAM 表進行分組,並把它們作為一個對象進行引用。適用於超大規模數據場景,如數據倉庫。
Federated:提供了從多個物理機上聯接不同的 MySql 服務器來創建一個邏輯數據庫的能力。適用於分布式或者數據市場的場景。
Example:這種存儲引擎用以保存闡明如何開始寫新的存儲引擎的 MySql 源碼的例子。它主要針對於有興趣的開發人員。這種存儲引擎就是一個啥事也不做的 "存根"。你可以使用這種引擎創建表,但是你無法向其保存任何數據,也無法從它們檢索任何索引。對於整台服務器或整個 schema 你並不受限於使用同一種存儲引擎。你可以為所有表定義存儲引擎。比如,一個應用可能以 InnoDB 表為主,輔以一個 CSV 表用以導出數據到電子表格,少許 MEMORY 表用以臨時工作空間。
存儲引擎的選擇
MySql 提供的這些存儲引擎為不同的應用案例進行設計。下表為 MySql 提供的存儲引擎做了一個概述:
存儲引擎特性總結
特性 |
MyISAM |
Memory |
InnoDB |
Archive |
NDB |
存儲上限
NDB
RAM
64TB
無
384EB
事務支持
否
否
是
否
是
鎖粒度
表
表
行
表
行
MVCC
否
否
是
否
否
地理空間數據類型支持
是
否
是
是
是
地理空間索引支持
是
否
是
否
否
B-tree 索引
是
是
是
否
否
T-tree 索引
否
否
否
否
是
Hash 索引
否
是
否
否
是
全文檢索索引
是
否
是
否
否
聚集索引
否
否
是
否
否
數據緩存
否
N/A
是
否
是
索引緩存
是
N/A
是
否
是
數據壓縮
是
否
是
是
否
數據加密
是
是
是
是
是
支持數據庫集群
否
否
否
否
是
支持主從
是
是
是
是
是
支持外鍵
否
否
是
否
否
備份/時間點恢復
是
是
是
是
是
支持查詢緩存
是
是
是
是
是
更新數據字典的統計
是
是
是
是
是
注意
InnoDB 在 MySQL 5.7.5 及以後的版本才支持地理空間索引InnoDB 通過其自適應哈希索引的特性內置進行哈希索引優化InnoDB 在 MySql 5.6.4 及以後版本才能支持 FULLTEXT 索引MyISAM 只能在行壓縮格式時支持數據壓縮。使用了行壓縮的 MyISAM 表只讀InnoDB 表壓縮要求 InnoDB Barracuda 文件格式MySql 的數據加密是由服務器的加密函數提供,並非存儲引擎主從支持、備份/時間點恢復等功能也是由服務器提供,