日期:2014-05-16  浏览次数:20815 次

MySQL存储引擎简介(转)
MySQL存储引擎简介(转)

存储引擎是什么?
???? MySQL 中的 数据用各种不同的技术存储在文件(或者内存)中 。这些技术中的 每一种技术都使用不同的存储机制、索引技巧、锁定水平 并且最终提供广泛的不同的功能和能力。通过选择不同的技术,你能够获得额外的速度或者功能,从而改善你的应用的整体功能。

??? 例如,如果你在研究大量的临时数据,你也许需要使用内存存储引擎。内存存储引擎能够在内存中存储所有的表格数据。又或者,你也许需要一个支持 事务 处理的数据库(以确保 事务 处理不成功时数据的回退能力).这些不同的技术以及配套的相关功能在 MySQL 中被称作存储引擎(也称作表类型)。 MySQL 默认配置了许多不同的存储引擎,可以预先设置或者在 MySQL 服务器中启用。

选择如何存储和检索你的数据的这种灵活性是 MySQL 为什么如此受欢迎的主要原因。 其它数据库系统(包括大多数商业选择)仅支持一种类型的数据存储。 遗憾 的是, 其它类型的数据库解决方案采取的“一个尺码满足一切需求”的方式意味着你要么就牺牲一些性能,要么你就用几个小时甚至几天的时间详细调整你的数据 库。 使用 MySQL ,我们仅需要修改我们使用的存储引擎就可以了。

如何确定有哪些存储引擎可用

你可以在 MySQL (假设是 MySQL 服务器4.1.2以上版本)中使用显示引擎的命令得到一个可用引擎的列表。
mysql > mysql > show engines;
Engine???? ?? Support Comment
MyISAM???? DEFAULT Default engine as of MySQL 3.23 with great performance????
MEMORY???? YES?? Hash based, stored in memory, useful for temporary tables??
InnoDB???? ????? YES???? Supports transactions, row-level locking, and foreign keys???