什么是mysql存储引擎_mysql引擎基础概念

9次阅读

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

什么是 mysql 存储引擎_mysql 引擎基础概念

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:所有数据存内存,读写极快,但重启即丢失,适合临时缓存、中间计算结果等短期用途

怎么查和改引擎

查看当前支持哪些引擎:

SHOW ENGINES;

查看某张表用的什么引擎:

SHOW CREATE TABLE 表名;SELECT ENGINE FROM information_schema.TABLES WHERE TABLE_SCHEMA=’db 名 ’ AND TABLE_NAME=’ 表名 ’;

修改已有表的引擎(会重建表,注意锁和时间):

ALTER TABLE 表名 ENGINE=InnoDB;

text=ZqhQzanResources