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???