MySQL嵌套事务所遇到的问题

发布时间 - 2026-01-10 23:17:14    点击率:

MySQL是支持嵌套事务的,但是没多少人会这么干的…. 前段时间在国外看到一些老外在争论MySQL嵌套事务的场景必要性。 逗死我了, 这嵌套的鬼畜用法还有啥场景必要性。   跟以前的dba同事聊过, 得知,在任何场景下都不要使用MySQL嵌套的事务。

那么使用MySQL嵌套事务会遇到什么问题 ?

mysql> select * from ceshi; 
+------+ 
| n  | 
+------+ 
|  1 | 
+------+ 
1 row in set (0.00 sec) 
 
mysql> start transaction ; 
Query OK, 0 rows affected (0.00 sec) 
 
mysql> insert into ceshi values(2); 
Query OK, 1 row affected (0.00 sec) 
 
mysql> start transaction ; 
Query OK, 0 rows affected (0.00 sec) 
 
mysql> insert into ceshi values(3); 
Query OK, 1 row affected (0.00 sec) 
 
mysql> commit; 
Query OK, 0 rows affected (0.00 sec) 
 
mysql> rollback; 
Query OK, 0 rows affected (0.00 sec) 


虽然我在最后rollback回滚了,但是数据显示是  1 2 3  .    原本大家以为我的事务虽然是嵌套的状态,但感觉最后rollback回滚了,其实我们希望看到的结果是 子事务执行成功,外层事务的失败会回滚的。  但事实不是这样的,最后的结果是  1 2 3 .

+-----+ 
| n   | 
+-----+ 
|  1 | 
|  2 | 
|  3 | 
+-----+ 

当sql解释器遇到 start transaction 时候会触发commit… !!!   

begin_1  sql_1  begin_2  sql_2  sql_3 commit_1  rollback_1  .

begin_2 被执行的时候, sql_1 已经就被提交了, 当你再去执行commit_1的时候,那么sql_2 和 sql_3 就被提交了.    这时候你再去rollback,一定用都没有….    因为先前都提交完了,你能回滚啥…

前面说过 在架构上一般很少很少有人会 嵌套使用事务,但有时候不小心被嵌套了。 我们拿python的项目来说,首先我们使用装饰器来实现事务的包装, 接着数据处理 def a() 和  def b() 函数都被事务被包装起来, 单纯的用a 和 b 都没关系,都是单事务。  如果 a 逻辑里又调用 b, 那么会发生什么?   对的,事务嵌套了…    我想这是绝大数业务开发都会遇到的问题。

那么怎么规避这风险 ?  可以加锁呀….   设立一个全局锁,当子事务创建前会判断锁的状态….

如果你是flask的框架,可以使用 flask g 全局变量。  

如果是django框架, 那么可以使用 thread local使用全局变量。

如果是tornado、gevent这种异步io架构,可以使用 fd 做协程变量的关联。

@decorator
def with_transaction(f, *args, **kwargs):
 
  db = connection.get_db_by_table("*")
  try:
    db.begin()
    ret = f(*args, **kwargs)
    db.commit()
  except:
    db.rollback()
    raise
  return ret
 
 
@with_transaction
def hide(self):
  '''订单不在app端显示'''
  if self.status not in OrderStatus.allow_deletion_statuses():
    raise OrderStatusChangeNotAllowed(self.status, OrderStatus.deleted)
...
 
 
@with_transaction
def change_receipt_info(self, address, name, phone):
  region = Region.get_by_address(address)
  ...

当我们去执行下面语句的时候,事务会被强制提交.   当然这里前提是 autocommit = True 。

ALTER FUNCTION  
ALTER PROCEDURE  
ALTER TABLE  
BEGIN  
CREATE DATABASE  
CREATE FUNCTION  
CREATE INDEX  
CREATE PROCEDURE  
CREATE TABLE  
DROP DATABASE  
DROP FUNCTION  
DROP INDEX  
DROP PROCEDURE  
DROP TABLE  
UNLOCK TABLES  
LOAD MASTER DATA  
LOCK TABLES  
RENAME TABLE  
TRUNCATE TABLE  
SET AUTOCOMMIT=1  
START TRANSACTION  


# mysql嵌套查询  # mysql  # 游标嵌套  # 嵌套子查询  # PHP中实现MySQL嵌套事务的两种解决方案  # MySQL存储过程例子(包含事务  # 输出参数  # 嵌套调用)  # 可以使用  # 再去  # 人会  # 都是  # 这是  # 全局变量  # 我想  # 我在  # 你是  # 结果是  # 都没  # 当你  # 说过  # 你能  # 上一  # 我了  # 数据处理  # 当我们  # 在国外  # 来实现 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: javascript中的try catch异常捕获机制用法分析  Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体  如何用AWS免费套餐快速搭建高效网站?  Python制作简易注册登录系统  JavaScript模板引擎Template.js使用详解  如何在云主机快速搭建网站站点?  百度浏览器网页无法复制文字怎么办 百度浏览器复制修复  Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】  如何注册花生壳免费域名并搭建个人网站?  Laravel如何使用查询构建器?(Query Builder高级用法)  如何在自有机房高效搭建专业网站?  php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】  Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程  为什么php本地部署后css不生效_静态资源加载失败修复技巧【技巧】  韩国服务器如何优化跨境访问实现高效连接?  使用豆包 AI 辅助进行简单网页 HTML 结构设计  独立制作一个网站多少钱,建立网站需要花多少钱?  七夕网站制作视频,七夕大促活动怎么报名?  魔方云NAT建站如何实现端口转发?  通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】  如何快速搭建虚拟主机网站?新手必看指南  用yum安装MySQLdb模块的步骤方法  在线制作视频网站免费,都有哪些好的动漫网站?  晋江文学城电脑版官网 晋江文学城网页版直接进入  如何快速生成ASP一键建站模板并优化安全性?  Linux系统命令中screen命令详解  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  高端建站如何打造兼具美学与转化的品牌官网?  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  linux写shell需要注意的问题(必看)  悟空识字怎么关闭自动续费_悟空识字取消会员自动扣费步骤  弹幕视频网站制作教程下载,弹幕视频网站是什么意思?  如何制作一个表白网站视频,关于勇敢表白的小标题?  Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  如何在腾讯云服务器上快速搭建个人网站?  网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?  Laravel怎么生成URL_Laravel路由命名与URL生成函数详解  深圳网站制作培训,深圳哪些招聘网站比较好?  如何快速搭建高效可靠的建站解决方案?  米侠浏览器网页背景异常怎么办 米侠显示修复  零服务器AI建站解决方案:快速部署与云端平台低成本实践  如何解决hover在ie6中的兼容性问题  网站制作壁纸教程视频,电脑壁纸网站?  如何在宝塔面板中创建新站点?  Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】  JavaScript如何实现音频处理_Web Audio API如何工作?  如何实现建站之星域名转发设置?  Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】