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助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。

相关推荐
灰色人生qwer2 小时前
Python 规则:带默认值的参数必须放在不带默认值的后面
linux·windows·python
難釋懷2 小时前
Redis通信协议-基于Socket自定义Redis的客户端
数据库·redis·缓存
环流_2 小时前
redis:AOF
数据库·redis·spring
2401_884454152 小时前
如何防止SQL触发器导致性能下降_通过精简触发器逻辑
jvm·数据库·python
m0_596749092 小时前
Golang如何做Clean Architecture_Golang整洁架构教程【详解】
jvm·数据库·python
czt_java2 小时前
线程安全问题
java·开发语言·jvm
半夜修仙2 小时前
Redis入门
数据库·redis·缓存
KaMeidebaby2 小时前
卡梅德生物技术快报|单 B 细胞抗体筛选服务:技术架构、流程实现与数据验证
前端·数据库·其他·百度·新浪微博
2401_867623982 小时前
如何管理应用锁_DBMS_LOCK申请自定义锁控制并发逻辑
jvm·数据库·python