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

相关推荐
曲幽1 小时前
FastAPI 身份验证总踩坑?这份 FastAPI Users “避坑指南”请收好
python·fastapi·web·jwt·oauth2·user·authentication
素材积累1 小时前
博士后出站来深可申请的项目补贴等
数据库
装不满的克莱因瓶2 小时前
掌握 RNN 与 LSTM 模型结构
人工智能·python·rnn·深度学习·神经网络·ai·lstm
何以解忧,唯有..2 小时前
Python包管理工具pip:从入门到精通
开发语言·python·pip
金銀銅鐵2 小时前
用 Tkinter 实现简单的猜数字游戏
后端·python
copyer_xyf2 小时前
Python 模块与包的导入导出
前端·后端·python
_1_73 小时前
SQL Server 磁盘满了 收缩日志
数据库·sqlserver
ice8130331813 小时前
【Python】Matplotlib折线图绘制
开发语言·python·matplotlib
copyer_xyf3 小时前
Python venv 虚拟环境
前端·后端·python
basketball6163 小时前
Redis基础:1. Redis介绍
数据库·redis·缓存