数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

如何选择合适的MySQL存储引擎


发布日期:2018年02月06日
 
如何选择合适的MySQL存储引擎

MySQL有多种存储引擎

MyISAMInnoDBMERGEMEMORY(HEAP)BDB(BerkeleyDB)EXAMPLEFEDERATEDARCHIVECSVBLACKHOLE

MySQL支持数个存储引擎作为对不同表的类型的处理器MySQL存储引擎包括处理事务安全表的引擎和处理非事务安全表的引擎

◆ MyISAM管理非事务表它提供高速存储和检索以及全文搜索能力MyISAM在所有MySQL配置里被支持它是默认的存储引擎除非你配置MySQL默认使用另外一个引擎

◆ MEMORY存储引擎提供内存中MERGE存储引擎允许集合将被处理同样的MyISAM表作为一个单独的表就像MyISAM一样MEMORY和MERGE存储引擎处理非事务表这两个引擎也都被默认包含在MySQL中

注释MEMORY存储引擎正式地被确定为HEAP引擎

◆ InnoDB和BDB存储引擎提供事务安全表BDB被包含在为支持它的操作系统发布的MySQLMax二进制分发版里InnoDB也默认被包括在所 有MySQL 二进制分发版里你可以按照喜好通过配置MySQL来允许或禁止任一引擎

◆ EXAMPLE存储引擎是一个存根引擎它不做什么你可以用这个引擎创建表但没有数据被存储于其中或从其中检索这个引擎的目的是服务在 MySQL源代码中的一个例子它演示说明如何开始编写新存储引擎同样它的主要兴趣是对开发者

◆ NDB Cluster是被MySQL Cluster用来实现分割到多台计算机上的表的存储引擎它在MySQLMax 二进制分发版里提供这个存储引擎当前只被Linux Solaris 和Mac OS X 支持在未来的MySQL分发版中我们想要添加其它平台对这个引擎的支持包括Windows

◆ ARCHIVE存储引擎被用来无索引地非常小地覆盖存储的大量数据

◆ CSV存储引擎把数据以逗号分隔的格式存储在文本文件中

◆ BLACKHOLE存储引擎接受但不存储数据并且检索总是返回一个空集

◆ FEDERATED存储引擎把数据存在远程数据库中在MySQL 它只和MySQL一起工作使用MySQL C Client API在未来的分发版中我们想要让它使用其它驱动器或客户端连接方法连接到另外的数据源

当你创建一个新表的时候你可以通过添加一个ENGINE 或TYPE 选项到CREATE TABLE语句来告诉MySQL你要创建什么类型的表

CREATE TABLE t (i INT) ENGINE = INNODB;

CREATE TABLE t (i INT) TYPE = MEMORY;

虽然TYPE仍然在MySQL 中被支持现在ENGINE是首选的术语

如何选择最适合你的存储引擎呢?

下述存储引擎是最常用的

◆ MyISAM默认的MySQL插件式存储引擎它是在Web数据仓储和其他应用环境下最常使用的存储引擎之一注意通过更改STORAGE_ENGINE配置变量能够方便地更改MySQL服务器的默认存储引擎

◆ InnoDB用于事务处理应用程序具有众多特性包括ACID事务支持

◆ BDB可替代InnoDB的事务引擎支持COMMITROLLBACK和其他事务特性

◆ Memory将所有数据保存在RAM中在需要快速查找引用和其他类似数据的环境下可提供极快的访问

◆ Merge允许MySQL DBA或开发人员将一系列等同的MyISAM表以逻辑方式组合在一起并作为个对象引用它们对于诸如数据仓储等VLDB环境十分适合

◆ Archive为大量很少引用的历史归档或安全审计信息的存储和检索提供了完美的解决方案

◆ Federated能够将多个分离的MySQL服务器链接起来从多个物理服务器创建一个逻辑数据库十分适合于分布式环境或数据集市环境

◆ Cluster/NDBMySQL的簇式数据库引擎尤其适合于具有高性能查找要求的应用程序这类查找需求还要求具有最高的正常工作时间和可用性

◆ Other其他存储引擎包括CSV(引用由逗号隔开的用作数据库表的文件)Blackhole(用于临时禁止对数据库的应用程序输入)以及Example引擎(可为快速创建定制的插件式存储引擎提供帮助)

请记住对于整个服务器或方案你并不一定要使用相同的存储引擎你可以为方案中的每个表使用不同的存储引擎这点很重要

上一篇:解决MySQL 5数据库连接超时问题

下一篇:MySQL优化之数据类型的使用