0

0

mysql事务是否支持嵌套_mysql限制说明

P粉602998670

P粉602998670

发布时间:2026-01-11 01:19:25

|

945人浏览过

|

来源于php中文网

原创

MySQL不支持真正嵌套事务,第二次START TRANSACTION会隐式提交前一个事务;唯一模拟方式是使用SAVEPOINT实现局部回滚,ORM框架的“嵌套事务”实为基于SAVEPOINT的计数器机制。

mysql事务是否支持嵌套_mysql限制说明

MySQL 本身不支持真正的嵌套事务。你写两个 START TRANSACTION,第二个会隐式提交第一个——不是报错,而是“悄无声息地 commit”,导致外层 ROLLBACK 完全失效。

为什么 START TRANSACTION 会自动提交上一个事务?

这是 MySQL 的硬性行为,不是 bug,是设计如此。只要当前连接处于活跃事务中,再执行 START TRANSACTIONBEGINBEGIN WORK,MySQL 就会立即执行一次隐式 COMMIT,然后开启新事务。

  • 哪怕你只写了 BEGIN 两次,也等价于:
    BEGIN;
    -- 做点事
    BEGIN; -- 此时前一个事务已 COMMIT
  • autocommit=0 是前提,否则连第一个事务都启不动
  • MyISAM 引擎完全无视事务语句,必须用 InnoDB

想“模拟嵌套”?用 SAVEPOINT 是唯一靠谱方案

MySQL 支持 SAVEPOINT,它不是嵌套事务,但能实现“局部回滚”,这是框架(如 Laravel、ThinkPHP)所谓“嵌套事务”的底层原理。

  • SAVEPOINT sp1;:打一个标记点
  • ROLLBACK TO sp1;:回滚到该点,之后的修改丢弃,但事务仍活跃
  • RELEASE SAVEPOINT sp1;:删除标记点(非必需)
  • 注意:SAVEPOINT 不能跨连接,也不能在存储过程/触发器里滥用(可能触碰 max_sp_recursion_depth 限制)

示例:

发卡宝-卡密寄售系统
发卡宝-卡密寄售系统

发卡宝是一个专业的软件卡密等虚拟商品在线交易平台,拥有多种兑换方式,费率低,结算快,正规企业平台一直稳定运营,24小时不间断提供自动发卡服务。【模板说明】试用版自带一套模板(响应式)【环境支持】PHP环境 / 200M或以上空间大小 / 开启父路径 / 设置index.php为默认首页 / 目录写入权限需要开启【数据库】MySQL【安装步骤】将文件上传至空间目录,运行“http://域名/inst

下载
BEGIN;
INSERT INTO users (name) VALUES ('Alice');
SAVEPOINT after_alice;
INSERT INTO users (name) VALUES ('Bob');
-- 发现 Bob 不合法,只撤回这一步
ROLLBACK TO after_alice;
COMMIT;

ORM 框架的“嵌套事务”其实是障眼法

ThinkPHP、Laravel 等框架的 startTrans() / DB::transaction() 看似支持嵌套,实则靠计数器 + SAVEPOINT 实现:

  • 第一次调用 → 执行 BEGIN
  • 第二次调用 → 执行 SAVEPOINT trans2
  • 回滚内层 → 执行 ROLLBACK TO trans2
  • 只有最外层 commit()rollback() 才真正操作 MySQL 事务状态
  • 如果框架没检测到 supportSavepoint()(比如某些低版本 MySQL 或禁用模式),嵌套会直接退化成“每次 begin 都 commit 上次”,数据一致性崩塌

最容易被忽略的三个坑

很多线上事故不是因为不会写事务,而是栽在这几个细节上:

  • 触发器里改数据 → 可能间接激活另一个触发器,形成嵌套调用,受 max_sp_recursion_depth 限制,默认为 0(禁止递归),超限报错 Error 1423
  • 同一张表的 BEFORE 触发器里再 UPDATE 自身 → 直接报 Error 1420(MySQL 明确禁止)
  • 没配好异常传播:比如 try/catch 里吞了异常却不 throw,导致框架以为“一切正常”,最终跳过 rollback()

事务不是套娃游戏,MySQL 给的工具就两样:BEGIN/COMMIT/ROLLBACKSAVEPOINT/ROLLBACK TO。把它们用对,比追求“嵌套语法糖”重要得多。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

316

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

271

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

367

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

366

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

81

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

64

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

67

2025.08.05

mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

658

2023.06.20

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

25

2026.01.09

热门下载

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

精品课程

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

共48课时 | 1.7万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 785人学习

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

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