内容好多,简要了解了一下各种存储引擎的特点。InnoDB,MyISAM,MEMORY用的会比较多一些。文档里说MyISAM是默认设置,但实际上InnoDB才是默认设置,可能是现在的数据库大多都需要事务处理吧,如果不需要的话用MyISAM会获得效率上的提升。MEMORY我一般是用来建立临时表,还没有尝试过把整个数据库都弄成MEMORY类型。以下来自文档:
MySQL支持数个存储引擎作为对不同表的类型的处理器。MySQL存储引擎包括处理事务安全表的引擎和处理非事务安全表的引擎:
-MyISAM管理非事务表。它提供高速存储和检索,以及全文搜索能力。MyISAM在所有MySQL配置里被支持,它是默认的存储引擎,除非你配置MySQL默认使用另外一个引擎。(NOTE:MyISAM不仅不支持事务,而且也不支持外键)
注释:MEMORY存储引擎正式地被确定为HEAP引擎。
- InnoDB和BDB存储引擎提供事务安全表。BDB被包含在为支持它的操作系统发布的MySQL-Max二进制分发版里。InnoDB也 默认被包括在所有MySQL 5.1二进制分发版里,你可以按照喜好通过配置MySQL来允许或禁止任一引擎。
- EXAMPLE存储引擎是一个“存根”引擎,它不做什么。你可以用这个引擎创建表,但没有数据被存储于其中或从其中检索。这个引擎的目的是服务 ,在MySQL源代码中的一个例子,它演示说明如何开始编写新存储引擎。同样,它的主要兴趣是对开发者。
- NDB Cluster是被MySQL Cluster用来实现分割到多台计算机上的表的存储引擎。它在MySQL-Max 5.1二进制分发版里提供。这个存储引擎当前只被Linux, Solaris, 和Mac OS X 支持。在未来的MySQL分发版中,我们想要添加其它平台对这个引擎的支持,包括Windows。
- ARCHIVE存储引擎被用来无索引地,非常小地覆盖存储的大量数据。
- CSV存储引擎把数据以逗号分隔的格式存储在文本文件中。
- BLACKHOLE存储引擎接受但不存储数据,并且检索总是返回一个空集。