MySQL嵌套事务所遇到的问题的代码实例详解

这篇文章主要介绍了mysql嵌套事务所遇到的问题的相关资料,需要的朋友可以参考下

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, 那么会发生什么?   对的,事务嵌套了…    我想这是绝大数业务开发都会遇到的问题。

Kotlin Android 中文开发帮助文档 PDF版 Kotlin Android 中文开发帮助文档 PDF版

这本书并不是一本语言参考书,但它是一个Android开发者去学习Kotlin并且使用在自己项目中的一个工具。我会通过使用一些语言特性和有趣的工具和库来解决很多我们在日常生活当中都会遇到的典型问题。 这本书是非常具有实践性的,所以我建议你在电脑面前跟着我的例子和代码实践。无论何时你都可以在有一些想法的时候深入到实践中去。 这本书适合你吗? 写这本书是为了帮助那些有兴趣 使用Kotlin语言来进行开发的Android开发者。 如果你符合下面这些情况,那这本书是适合你的: 你有相关Android开发和Andro

Kotlin Android 中文开发帮助文档 PDF版 11 查看详情 Kotlin Android 中文开发帮助文档 PDF版

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

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

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

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

@decoratordef 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_transactiondef hide(self):  '''订单不在app端显示'''  if self.status not in OrderStatus.allow_deletion_statuses():    raise OrderStatusChangeNotAllowed(self.status, OrderStatus.deleted)...  @with_transactiondef 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嵌套事务所遇到的问题的代码实例详解的内容,更多相关内容请关注PHP中文网(www.php.cn)!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/799929.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月26日 17:26:59
下一篇 2025年11月26日 17:32:24

相关推荐

  • 如何用Golang实现JWT认证 生成和验证Token的完整流程

    golang实现jwt认证的核心是生成带用户身份信息的签名token并验证其有效性,首先需使用github.com/golang-jwt/jwt/v5库定义包含用户id、角色等信息并嵌入jwt.registeredclaims的自定义结构体myclaims,接着通过hs256算法和密钥生成token…

    2025年12月15日
    000
  • Golang函数调用开销如何降低 内联优化与逃逸分析技巧

    降低go语言函数调用开销的核心在于编译器的内联优化和逃逸分析,前者通过将小函数体直接嵌入调用点以消除调用开销,后者通过将尽可能多的变量分配在栈上以减少堆内存分配和gc压力,二者协同工作显著提升了程序性能;编译器根据函数体大小、复杂度、是否包含go语句或defer等因素决定是否内联,并可通过go to…

    2025年12月15日
    000
  • 如何用Golang创建HTTP服务器 实现路由处理与请求解析

    答案:使用 net/http 包可快速创建 HTTP 服务器并实现路由与请求解析。1. 通过 http.ListenAndServe 启动服务器,http.HandleFunc 注册路径处理器。2. 使用 r.URL.Path 获取访问路径,r.Method 区分请求方法,实现 REST 风格路由。…

    2025年12月15日
    000
  • Golang实现CI/CD流水线怎么做 集成GitHub Actions实践

    答案:通过GitHub Actions实现Golang项目CI/CD,包含构建、测试、部署及依赖管理、覆盖率报告和代码质量检查。首先创建.github/workflows目录并编写ci-cd.yml文件,定义在push和pull_request到main分支时触发workflow;workflow包…

    2025年12月15日
    000
  • Go 并发编程:多 Goroutine 间的高效通信与常见陷阱

    本文深入探讨 Go 语言中 Goroutine 之间基于通道(Channel)的并发通信机制。通过分析一个多 Goroutine 间数据传输的实际案例,揭示了因通道未正确初始化导致的常见死锁问题,并提供了详细的解决方案。同时,文章还介绍了通道的单向性、类型安全等高级特性,并提供了避免并发陷阱和优化通…

    2025年12月15日
    000
  • Go语言并发编程:多源输入与灵活通信模式

    本文深入探讨Go语言中并发协程间的高效通信机制,重点阐述一个协程如何从多个不同通道接收数据,并根据需求进行处理。我们将详细介绍通过顺序读取、使用select语句进行灵活选择的策略,并探讨Go通道自带的多读写特性,以及在消息中嵌入回复通道的先进通信模式,旨在帮助开发者构建健壮且响应迅速的并发应用。 G…

    2025年12月15日
    000
  • Go语言中并发协程间的高效通信与多通道数据处理

    本文深入探讨Go语言中协程(goroutine)如何通过通道(channel)进行高效并发通信,并重点讲解单个协程如何从多个通道接收数据。我们将介绍两种主要的接收策略:顺序阻塞式接收和使用select语句进行的非阻塞或公平选择接收,并通过代码示例进行说明。此外,文章还将探讨一种高级通信模式——通过消…

    2025年12月15日
    000
  • Go 语言并发编程:多通道数据接收与通信模式

    本文深入探讨Go语言中goroutine如何高效地从多个并发源接收数据。我们将详细介绍两种主要的数据接收策略:顺序接收和使用select语句进行非确定性接收。此外,文章还将阐述Go通道的多写者/多读者特性,并介绍一种常见的通信模式——通过消息携带回复通道,以构建更灵活、响应式的并发系统。通过本文,读…

    2025年12月15日
    000
  • Go语言并发实践:Goroutine间的高效通信与模式

    本文深入探讨Go语言中Goroutine间的高效通信机制。重点阐述了如何利用Channel实现单个Goroutine从多个源接收数据,包括顺序处理和使用select进行多路复用。此外,还将介绍Channel的多读写特性,以及通过消息体携带回复Channel的高级通信模式,旨在帮助开发者构建健壮、灵活…

    2025年12月15日
    000
  • Go语言并发编程:灵活处理多源通道数据与通信模式

    本文深入探讨Go语言中Goroutine间高效且灵活的并发通信模式。我们将学习如何让一个Goroutine同时或选择性地接收来自多个源(其他Goroutine)的数据,包括顺序接收和使用select语句进行非阻塞或公平选择。此外,文章还将介绍Go通道的多写入者特性,以及通过在消息中传递回复通道来实现…

    2025年12月15日
    000
  • Go语言多返回值函数:理解与高效处理

    Go语言函数支持返回多个值,这在处理错误或返回复杂结果时非常有用。然而,直接访问这些多返回值中的特定单个值并非像数组索引那样直观。本文将深入探讨Go语言中处理多返回值函数的常见方法,包括使用空白标识符进行赋值,以及通过编写辅助函数来封装特定逻辑,从而实现更简洁、更符合Go语言习惯的代码。 Go语言多…

    2025年12月15日
    000
  • Go语言中多返回值函数的处理策略与最佳实践

    Go语言函数支持返回多个值,但不能像数组一样直接通过索引访问。本文将深入探讨Go多返回值函数的处理方法,强调标准赋值与解构的重要性,并介绍如何通过创建特定辅助函数来优雅地提取所需值或简化错误处理,如Go标准库中的Must模式,以提升代码的可读性和健练性。 go语言以其简洁高效的设计哲学而闻名,其中一…

    2025年12月15日
    000
  • Go语言中多返回值函数的优雅处理与选择性访问策略

    Go语言函数支持返回多个值,这在处理错误或返回额外信息时非常有用。然而,直接访问或选择性地提取其中一个返回值并非像数组索引那样直观。本文将深入探讨Go语言中处理多返回值函数的常见挑战,并介绍Go标准库推崇的、也是最符合Go语言哲学的一种优雅解决方案:利用辅助函数(Helper Functions)来…

    2025年12月15日
    000
  • Golang模糊测试如何配置 使用go test -fuzz进行自动化探索测试

    模糊测试是通过输入大量随机数据来发现程序漏洞的自动化方法,golang的go test -fuzz工具可辅助实现。首先,创建以_test.go结尾的测试文件并编写以fuzz开头的模糊测试函数,接收*testing.fuzz参数并在其中调用被测函数;其次,使用-fuzz、-fuzztime和-fuzz…

    2025年12月15日 好文分享
    000
  • 如何用Golang写入大文件 使用缓冲写入优化I/O效率技巧

    使用bufio.Writer可显著提升大文件写入性能,通过缓冲减少系统调用。1. 创建带缓冲的写入器,数据先写入内存缓冲区;2. 合理设置缓冲区大小(如64KB或1MB)以匹配I/O特性;3. 写入完成后必须调用Flush确保数据落盘;4. 可选调用file.Sync()保证数据持久化。示例代码展示…

    2025年12月15日
    000
  • 怎样收集Golang程序的错误统计 集成Sentry等错误监控系统

    安装sentry-go SDK并初始化客户端,设置DSN、环境和版本;2. 使用sentry.CaptureException捕获error,结合defer和recover上报panic;3. 在Gin或Echo等Web框架中通过中间件自动捕获异常;4. 通过WithScope添加标签、用户和请求上…

    2025年12月15日
    000
  • 如何用Golang实现装饰器模式 通过函数包装扩展行为

    Golang通过函数式包装实现装饰器模式,利用高阶函数动态扩展函数行为,保持代码简洁与复用。定义统一函数类型Handler作为契约,loggingDecorator和authDecorator分别添加日志与权限检查功能,通过闭包包装原函数并插入前置或后置逻辑。执行时按装饰顺序从外到内调用,响应逆序返…

    2025年12月15日
    000
  • 如何在Golang中集成Nix包管理器 详解可复现开发环境配置方法

    答案:在Go项目中引入Nix可实现高度可复现的开发环境。通过shell.nix文件声明Go版本、工具链和系统依赖,结合direnv自动加载,确保团队成员和CI/CD环境一致,避免“在我机器上能跑”问题。Nix解决Go模块外的版本不一致痛点,支持精确版本控制、隔离依赖、简化多工具协作,并可通过二进制缓…

    2025年12月15日
    000
  • Go并发编程:使用Channel实现Goroutine间的通信

    本文介绍了如何使用Go语言中的channel实现goroutine之间的通信,并提供了一个完整的示例,展示了如何通过channel进行双向数据传递以及如何优雅地关闭channel,避免goroutine阻塞。通过学习本文,你将掌握Go并发编程中channel的核心用法,为构建高性能的并发应用奠定基础…

    2025年12月15日
    000
  • Golang测试如何集成数据库操作 讲解testcontainers启动临时数据库

    使用testcontainers启动临时数据库进行golang项目测试的步骤如下:1. 引入testcontainers-go库;2. 定义setuppostgres函数创建postgresql容器并返回连接字符串与清理函数;3. 在测试函数中调用该函数并执行数据库操作;4. 测试结束后通过清理函数…

    2025年12月15日 好文分享
    000

发表回复

登录后才能评论
关注微信