0

0

mysql中存储引擎的自动提交与事务管理

P粉602998670

P粉602998670

发布时间:2026-01-21 02:43:21

|

740人浏览过

|

来源于php中文网

原创

MySQL 默认 autocommit 是开启的,即每条 DML 语句自动提交,仅 START TRANSACTION 后才进入事务;InnoDB 支持完整事务,MyISAM 不支持;DDL 总是隐式提交,会中断当前事务。

mysql中存储引擎的自动提交与事务管理

MySQL 默认的 autocommit 行为到底开没开?

绝大多数 MySQL 客户端(包括 mysql 命令行、Navicat、DBeaver)连接成功后,autocommit 默认是开启的。你可以用 SELECT @@autocommit; 确认——返回 1 就表示自动提交已启用。

这意味着:每条 INSERTUPDATEDELETE 语句执行完就立刻持久化,不依赖 COMMIT,也无法用 ROLLBACK 撤销。

  • 只有显式执行 START TRANSACTIONBEGIN 后,才进入事务上下文,autocommit 临时失效
  • SET autocommit = 0; 可全局关闭当前会话的自动提交,但不推荐长期使用——容易忘记恢复,导致后续所有 DML 都滞留在未提交状态
  • DDL 语句(如 CREATE TABLEALTER TABLE)无论 autocommit 如何,都会隐式触发 COMMIT

InnoDB 和 MyISAM 对事务的支持差异

存储引擎决定你能不能真正用上事务。InnoDB 支持完整的 ACID 事务、行级锁和外键;MyISAM 完全不支持事务,也没有 ROLLBACK 能力——哪怕你写了 START TRANSACTION,执行 ROLLBACK 也什么都不会发生。

检查表引擎用:SHOW CREATE TABLE table_name;SELECT ENGINE FROM information_schema.TABLES WHERE TABLE_SCHEMA = 'db_name' AND TABLE_NAME = 'table_name';

  • 创建表时没指定 ENGINE=InnoDB,MySQL 8.0+ 默认用 InnoDB,但老版本或某些配置下可能 fallback 到 MyISAM
  • ALTER TABLE t ENGINE=InnoDB; 可在线转换(MySQL 5.6+),但大表会锁写,且需足够磁盘空间做重建
  • 如果误用了 MyISAM 表却写了事务逻辑,ROLLBACK 不报错但也不起作用——这是最隐蔽的“事务失效”场景

事务中混合 DML 与 DDL 的陷阱

START TRANSACTION 内执行 DDL(比如 ALTER TABLE),MySQL 会**立即隐式提交当前事务**,然后执行 DDL,再开启新事务(如果后续还有 DML)。

商务通(在线客服系统)
商务通(在线客服系统)

一款无需安装的即时交流系统,只需申请一个帐号,将一段代码嵌入贵站网页中,就可以让客服人员发现所有到达您网站的访客,而且可以看到访客的来源、使用的搜索引擎等,您可以主动发起对话与访客沟通,进行产品推销,从而大大提高产品销售成功率。 还是一款协同管理软件,在保持与客户信息通畅的同时,也保持公司内部之间的信息交流,从而提高企业的工作效率和客户服务质量。 管理员帐号:biiz.cn 密码:biiz.cn

下载

这意味着:

  • DDL 前的 DML 已经不可回滚
  • DDL 后的 DML 属于另一个事务,ROLLBACK 只能撤掉它,不影响前面已提交的部分
  • 这个行为在所有存储引擎中一致,和 autocommit 设置无关
START TRANSACTION;
INSERT INTO users (name) VALUES ('alice');
ALTER TABLE users ADD COLUMN age INT;  -- 此刻 INSERT 已提交
INSERT INTO users (name) VALUES ('bob');  -- 这条可被 ROLLBACK
ROLLBACK;  -- 只撤销第二条 INSERT,'alice' 仍存在

应用层连接池里 autocommit 的常见误设

Java 的 HikariCP、Python 的 PyMySQL、Node.jsmysql2 等客户端库,通常默认将连接的 autocommit 设为 true。但有些框架(如旧版 Django)或自定义封装会改成 false,导致连接复用时事务状态“污染”。

典型表现:A 请求手动 begin + commit,B 请求复用同一连接但没显式开启事务,结果 B 的单条 UPDATE 却被卡在未提交状态,直到连接关闭或超时回滚。

  • 最佳实践:不在连接池层面统一关 autocommit,而是由业务逻辑按需控制——用 connection.begin() / start_transaction() 显式开启
  • 务必确认 ORM 或驱动是否在 execute() 前自动加了 START TRANSACTION(例如 SQLAlchemy 的 connection.execute(...) 默认不启事务,但 session.add() 会绑定到 session 级事务)
  • 监控 information_schema.INNODB_TRX 表,查长时间未提交的 trx_state = 'RUNNING' 事务,往往是连接池 + autocommit 配置混乱的直接证据

事务真正的复杂点不在语法,而在跨语句、跨连接、跨引擎的状态一致性。尤其当 DDL 插入事务中间,或连接被复用却未重置 autocommit 时,问题往往延迟暴露,排查成本远高于预防。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

769

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

661

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

764

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

639

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1305

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

549

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

709

2023.08.11

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.8万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 804人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号