MySQL存储引擎按表设定,同一数据库中不同表可使用不同引擎;InnoDB支持事务和行锁,MyISAM适合只读场景,MEMORY用于临时数据;可通过SHOW ENGINES、SHOW CREATE TABLE或ALTER TABLE修改引擎。

MySQL存储引擎是负责数据如何存储、怎么索引、怎样并发读写、是否支持事务和崩溃恢复的核心模块。它不是数据库级别的配置,而是**按表设定**的——同一库中,不同表可以使用不同引擎,比如一张订单表用InnoDB,一张日志表用MyISAM。
为什么叫“表类型”而不是“数据库引擎”
因为MySQL把引擎绑定在单个表上,建表时通过 ENGINE=xxx 明确指定,例如:
CREATE TABLE users (id INT, name VARCHAR(20)) ENGINE=InnoDB;
这说明引擎控制的是这张表的数据组织方式,而非整个数据库的行为。Oracle、SQL Server等系统没有这种灵活切换机制,它们只有一种内置存储逻辑。
主流引擎的核心差异点
目前最常用的是以下三种,各自解决不同场景问题:
- InnoDB:默认引擎(MySQL 5.5+),支持事务、行锁、外键、MVCC,适合高并发更新、强一致性要求的业务表(如订单、账户)
- MyISAM:不支持事务和行锁,但全表扫描快、全文索引成熟,适合以查询为主、极少更新的报表或归档表
- MEMORY:所有数据存内存,读写极快,但重启即丢失,适合临时缓存、中间计算结果等短期用途
怎么查和改引擎
查看当前支持哪些引擎:
本书将PHP开发与MySQL应用相结合,分别对PHP和MySQL做了深入浅出的分析,不仅介绍PHP和MySQL的一般概念,而且对PHP和MySQL的Web应用做了较全面的阐述,并包括几个经典且实用的例子。 本书是第4版,经过了全面的更新、重写和扩展,包括PHP5.3最新改进的特性(例如,更好的错误和异常处理),MySQL的存储过程和存储引擎,Ajax技术与Web2.0以及Web应用需要注意的安全
SHOW ENGINES;
查看某张表用的什么引擎:
SHOW CREATE TABLE 表名; 或 SELECT ENGINE FROM information_schema.TABLES WHERE TABLE_SCHEMA='db名' AND TABLE_NAME='表名';
修改已有表的引擎(会重建表,注意锁和时间):
ALTER TABLE 表名 ENGINE=InnoDB;









