如何选择合适的MySQL存储引擎
MySQL支持数个存储引擎作为对不同表的类型的处理器。MySQL存储引擎包括处理事务安全表的引擎和处理非事务安全表的引擎:
◆MyISAM管理非事务表。它提供高速存储和检索,以及全文搜索能力。MyISAM在所有MySQL配置里被支持,它是默认的存储引擎,除非你配置MySQL默认使用另外一个引擎。
◆MEMORY存储引擎提供“内存中”表。MERGE存储引擎允许集合将被处理同样的MyISAM表作为一个单独的表。就像MyISAM一样,MEMORY和MERGE存储引擎处理非事务表,这两个引擎也都被默认包含在MySQL中。
注释:MEMORY存储引擎正式地被确定为HEAP引擎。
◆InnoDB和BDB存储引擎提供事务安全表。BDB被包含在为支持它的操作系统发布的MySQL-Max二进制分发版里。InnoDB也默认被包括在所有MySQL5.1二进制分发版里,你可以按照喜好通过配置MySQL来允许或禁止任一引擎。
◆EXAMPLE存储引擎是一个“存根”引擎,它不做什么。你可以用这个引擎创建表,但没有数据被存储于其中或从其中检索。这个引擎的目的是服务,在MySQL源代码中的一个例子,它演示说明如何开始编写新存储引擎。同样,它的主要兴趣是对开发者。
◆NDBCluster是被MySQLCluster用来实现分割到多台计算机上的表的存储引擎。它在MySQL-Max5.1二进制分发版里提供。这个存储引擎当前只被Linux,Solaris,和MacOSX支持。在未来的MySQL分发版中,我们想要添加其它平台对这个引擎的支持,包括Windows。
◆ARCHIVE存储引擎被用来无索引地,非常小地覆盖存储的大量数据。
◆CSV存储引擎把数据以逗号分隔的格式存储在文本文件中。
◆BLACKHOLE存储引擎接受但不存储数据,并且检索总是返回一个空集。
◆FEDERATED存储引擎把数据存在远程数据库中。在MySQL5.1中,它只和MySQL一起工作,使用MySQLCClientAPI。在未来的分发版中,我们想要让它使用其它驱动器或客户端连接方法连接到另外的数据源。
当你创建一个新表的时候,你可以通过添加一个ENGINE或TYPE选项到CREATETABLE语句来告诉MySQL你要创建什么类型的表:
CREATETABLEt(iINT)ENGINE=INNODB;
CREATETABLEt(iINT)TYPE=MEMORY;
虽然TYPE仍然在MySQL5.1中被支持,现在ENGINE是首选的术语。
如何选择最适合你的存储引擎呢?
下述存储引擎是最常用的:
◆MyISAM:默认的MySQL插件式存储引擎,它是在Web、数据仓储和其他应用环境下最常使用的存储引擎之一。注意,通过更改STORAGE_ENGINE配置变量,能够方便地更改MySQL服务器的默认存储引擎。
◆InnoDB:用于事务处理应用程序,具有众多特性,包括ACID事务支持。
◆BDB:可替代InnoDB的事务引擎,支持COMMIT、ROLLBACK和其他事务特性。
◆Memory:将所有数据保存在RAM中,在需要快速查找引用和其他类似数据的环境下,可提供极快的访问。
◆Merge:允许MySQLDBA或开发人员将一系列等同的MyISAM表以逻辑方式组合在一起,并作为1个对象引用它们。对于诸如数据仓储等VLDB环境十分适合。
◆Archive:为大量很少引用的历史、归档、或安全审计信息的存储和检索提供了完美的解决方案。
◆Federated:能够将多个分离的MySQL服务器链接起来,从多个物理服务器创建一个逻辑数据库。十分适合于分布式环境或数据集市环境。
◆Cluster/NDB:MySQL的簇式数据库引擎,尤其适合于具有高性能查找要求的应用程序,这类查找需求还要求具有最高的正常工作时间和可用性。
◆Other:其他存储引擎包括CSV(引用由逗号隔开的用作数据库表的文件),Blackhole(用于临时禁止对数据库的应用程序输入),以及Example引擎(可为快速创建定制的插件式存储引擎提供帮助)。
请记住,对于整个服务器或方案,你并不一定要使用相同的存储引擎,你可以为方案中的每个表使用不同的存储引擎,这点很重要。
相关文章
- MySQL体系结构和存储引擎概述详解数据库
- MySQL存储过程函数:优化数据库性能(mysql存储过程函数)
- MySQL中调用存储过程的简单实现(mysql调用存储过程)
- MySQL存储布尔值:从简单到复杂(mysql存储布尔值)
- MySQL:如何建立且编码指定的数据库(mysql建库指定编码)
- MySQL 主从复制:实现数据安全可靠的分布式存储(mysql主从模式)
- MySQL中Limit用法:解析精通分页查询(mysql中limit用法)
- MySQL中乘法运算的实现(mysql乘法运算)
- MySQL数据存储:安全、可靠、可靠的存储方式(mysql数据存放)
- 数据迁移实现Redis到MySql的数据迁移(redis到mysql)
- MySQL 数据表引擎:灵活的功能性选择(mysql数据表引擎)
- MySQL过程返回值解读(mysql过程返回值)
- MySQL左连接重复问题解决(mysql左连接重复)
- MySQL存储过程:让数据更有效率(mysql储存过程)
- 查看MySQL日志:实现数据库管理(查询mysql日志)
- MySQL事务:维护数据的原子性和完整性(mysql的事务是什么)
- MySQL精准存储小数的方法(mysql存小数)
- MySQL 存储过程声明:优化数据库操作(mysql存储过程声明)
- MySQL 存储过程调试技巧分享(mysql调试存储过程)
- 尽在掌握:MySQL数据库完整指南(mysql大全)
- MySQL存储过程实现分页的巧妙方式(mysql存储分页)
- MySQL数据库备份:实现可靠的数据安全保障(mysql数据库备份策略)
- MySQL中char 6如何使用char 6数据类型进行数据存储(mysql中char 6)
- 深入解析MySQL中的ASC排序方式(mysql中asc是什么)
- MySQL个人优化提升数据库性能的方法(mysql个人优化)
- 数据库导入MySQL数据库Bak文件与MySQL的操作(bak怎么导入mysql)
- 10亿MySQL用户表让企业数据存储更轻松(10亿mysql用户表)
- MySQL保证数字不为负数(mysql 不为负数)
- MySQL最新版下载指南(mysql下载最新)
- 深入浅出了解MySQL中的存储区(mysql上的存储区)
- 如何高效读取 MySQL 上上亿数据(mysql上亿数据读取)