mysql在事务中执行DDL的后果_MySQL 8.0之前的限制

MySQL 8.0前ALTER TABLE会隐式提交事务,导致ROLLBACK失效;8.0起部分DDL支持原子性但受限于算法(如INSTANT),DROP DATABASE等仍强制提交;安全做法是DDL与DML物理隔离。MySQL 8.0 之前在事务里执行 ALTER TABLE 会自动提交不是报错,而是悄悄提交当前事务------这是最危险的地方。你写了个 BEGIN,中间夹了条 ALTER TABLE,后面再 ROLLBACK,发现前面的 INSERT 或 UPDATE 全没回滚,因为事务早被 DDL 强制结束了。原因很简单:MySQL 5.7 及更早版本不支持 DDL 的原子性,所有 DDL(CREATE、DROP、ALTER、RENAME)都会触发隐式提交(implicit commit),哪怕你没写 COMMIT。哪怕事务里只有 SELECT + ALTER TABLE,ALTER 执行完,事务状态就变成"已提交"SHOW VARIABLES LIKE 'autocommit' 设为 OFF 也拦不住------DDL 不吃这套如果你依赖事务边界做数据一致性校验(比如先改配置表再改主表),这个隐式提交会让校验完全失效错误现象:为什么 ROLLBACK 像没发生一样典型表现是:执行完 ALTER TABLE 后,再执行 ROLLBACK,命令成功返回,但之前做的 DML 没回滚。这不是 bug,是设计如此。你可以用 SELECT @@in_transaction 验证:在 ALTER 前它是 1,执行后立刻变 0;或者查 information_schema.INNODB_TRX,事务记录已经消失。错误日志里不会报错,也不会警告,安静得可怕应用层如果没检查事务状态,可能误以为整个逻辑块还在一个事务里ORM(如 Django、SQLAlchemy)若自动生成 DDL(比如迁移脚本),更容易踩中这个坑MySQL 8.0+ 的变化:DDL 支持原子性,但仍有条件8.0 引入了原子 DDL 日志(mysql.innodb_ddl_log),让部分 DDL 真正支持事务语义------但仅限于满足条件的操作。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。

相关推荐
Yushan Bai1 小时前
oracle exadata x9的存储节点重启问题分析
数据库·oracle
其实防守也摸鱼1 小时前
全新安装 SQL Server 并直接设置数据目录到 E 盘 完整步骤
数据库·sql·网络安全·sqlserver·教程·工具
2301_769340671 小时前
Golang怎么用gRPC Gateway_Golang gRPC Gateway教程【经典】
jvm·数据库·python
Jetev1 小时前
HTML函数运行时触控屏失灵是硬件故障吗_输入层兼容性测试【详解】
jvm·数据库·python
毋语天1 小时前
Python 进阶:元组、字典、集合与函数全解析
开发语言·python
wang3zc1 小时前
Golang怎么实现SSE服务端推送事件_Golang如何用Server-Sent Events实时推送数据【教程】
jvm·数据库·python
yexuhgu1 小时前
c++ trpc-cpp框架 c++如何使用腾讯trpc构建微服务
jvm·数据库·python
夏恪1 小时前
Go语言如何连接Redis_Go语言Redis连接操作教程【进阶】
jvm·数据库·python
七七powerful1 小时前
运维养龙虾--MongoDB 官方 Agent Skills 深度解析:为编码智能体注入专家级最佳实践
数据库·mongodb