位置: 编程技术 - 正文

PHP中实现MySQL嵌套事务的两种解决方案(php mysql教程)

编辑:rootadmin

推荐整理分享PHP中实现MySQL嵌套事务的两种解决方案(php mysql教程),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysqli php,mysqli php,如何用php操作mysql,php+mysql,php的mysql_query,php使用mysql,php中mysqli_query,php+mysql,内容如对您有帮助,希望把文章链接给更多的朋友!

一、问题起源

在MySQL的官方文档中有明确的说明不支持嵌套事务:但是在我们开发一个复杂的系统时难免会无意中在事务中嵌套了事务,比如A函数调用了B函数,A函数使用了事务,并且是在事务中调用了B函数,B函数也有一个事务,这样就出现了事务嵌套。这时候其实A的事务就意义不大了,为什么呢?上面的文档中就有提到,简单的翻译过来就是:所以我们就要在系统架构层面来支持事务的嵌套。所幸的是在一些成熟的ORM框架中都做了对嵌套的支持,比如doctrine或者laravel。接下来我们就一起来看下这两个框架是怎样来实现的。

友情提示,这两个框架的函数和变量的命名都比较的直观,虽然看起来很长,但是都是通过命名就能直接得知这个函数或者变量的意思,所以不要一看到那么一大坨就被吓到了 :)

二、doctrine的解决方案

PHP中实现MySQL嵌套事务的两种解决方案(php mysql教程)

首先来看下在doctrine中创建事务的代码(干掉了不相关的代码):这个函数的第一行用一个_transactionNestingLevel来标识当前嵌套的级别,如果是1,也就是还没有嵌套,那就用默认的方法执行一下START TRANSACTION就ok了,如果大于1,也就是有嵌套的时候,她会帮我们创建一个savepoint,这个savepoint可以理解为一个事务记录点,当需要回滚时可以只回滚到这个点。

然后看下rollBack函数:可以看到处理的方式也很简单,如果level是1,直接rollback,否则就回滚到前面的savepoint。

然后我们继续看下commit函数:算了,不费口舌解释这段了吧 :)

三、laravel的解决方案

laravel的处理方式相对简单粗暴一些,我们先来看下创建事务的操作:感觉如何?so easy吧?先判断当前有几个事务,如果是第一个,ok,事务开始,否则就啥都不做,那么为啥是啥都不做呢?继续往下看rollBack的操作:明白了吧?只有当当前事务只有一个的时候才会真正的rollback,否则只是将计数做减一操作。这也就是为啥刚才说laravel的处理比较简单粗暴一些,在嵌套的内层里面实际上是木有真正的事务的,只有最外层一个整体的事务,虽然简单粗暴,但是也解决了在内层新建一个事务时会造成commit的问题。原理就是这个样子了,为了保持完整起见,把commit的代码也copy过来吧!

MySQL中的if和case语句使用总结 Mysql的if既可以作为表达式用,也可在存储过程中作为流程控制语句使用,如下是做为表达式使用:IF表达式IF(expr1,expr2,expr3)如果expr1是TRUE(exprandexpr1NULL)

mysql中You can’t specify target table for update in FROM clause错误解决方法 mysql中Youcan'tspecifytargettableforupdateinFROMclause错误的意思是说,不能先select出同一表中的某些值,再update这个表(在同一语句中)。例如下面这个sql:deletefromt

MySQL查询和修改auto_increment的方法 本文实例讲述了MySQL查询和修改auto_increment的方法。分享给大家供大家参考。具体如下:查询表名为tableName的auto_increment值:SELECTAUTO_INCREMENTFROMinformation_sc

标签: php mysql教程

本文链接地址:https://www.jiuchutong.com/biancheng/321379.html 转载请保留说明!

上一篇:Mysql中存储UUID去除横线的方法(mysql存long)

下一篇:MySQL中的if和case语句使用总结(mysql,if)

  • 汇算清缴需要做分录吗
  • 个体户年报纳税额怎么填
  • 火车票可以抵扣多少增值税
  • 外来原始凭证包括哪些入库单
  • 二级分支机构不具有主体生产经营职能
  • 定额征收需要建账吗
  • 税收和税法是什么关系
  • 当月销项税大于进项税怎么办
  • 高速公路过路费计入什么会计科目
  • 当月作废的采购发票已认证账务如何处理?
  • 事业单位跨期发票的财务入账问题
  • 收回过去已确认的坏账
  • 公司收到股东的投资款以后怎么处理
  • 房地产建造运费怎么计算
  • 小规模纳税人按月申报还是按季申报
  • 个人是否可以开展募捐
  • 损益表和利润表的关系
  • 物流行业主营业务成本会计分录
  • 补偿金满一年不满一年半
  • 发票作废了还能查验吗
  • 去年盈利今年亏损怎么表达
  • 旅行社开具的发票能否作废
  • 盘点固定资产
  • 房企的预收账款是什么
  • 空白发票怎么用
  • 跨年的工会经费怎么做分录
  • 企业为开发新产品新技术新工艺
  • 判断技巧
  • php封装composer包
  • 三代税款手续费支付比例
  • PHP:session_cache_expire()的用法_Session函数
  • dc.exe是什么程序
  • 同一控制下的企业合并,合并方在企业合并中取得的资产
  • 发票开具时限是怎么规定的
  • vue3 计算属性
  • 两借两贷属于复合会计分录吗
  • 报表重分类和不重分类
  • 错误解决方法
  • arptables命令详解
  • 企业餐具属于流动资产吗
  • 织梦最新发表的作品
  • python frames
  • 企业利润分配的内容
  • 未分配利润是否可以全部分红
  • 什么叫金税四期呢?
  • 实收资本印花税是一年一交吗
  • 公司名下的车怎样领免检标志
  • 开发票,对方收取税点,如何计算?
  • 银行承兑汇票贴现的账务处理
  • 实收资本的入账金额包括消费税吗
  • 税控系统全额抵扣增值税申报
  • 工程施工的保险费的账务处理
  • 公司租用员工车辆维修费能报销吗
  • 支付上月采购货款
  • 商业承兑汇票怎么做账
  • 融资租赁可以折旧吗
  • 对公提现是什么意思啊
  • 公司活动费用分录
  • sqlserver数据库显示单个用户
  • sql中case when的用法
  • 电脑右下角windows设置在哪
  • win10edge浏览器如何切换到ie
  • web软件安装
  • svchost进程可以结束吗
  • centos screen命令
  • win8系统笔记本忘记开机密码怎么办
  • 下列有关javascript中call和apply
  • unity5.x游戏开发指南
  • android:gravity和android:layout_gravity的区别
  • linux修改磁盘格式指令
  • jquery制作简单的网页
  • 怎样屏蔽锁屏广告
  • linux启动的过程
  • unity怎么学
  • 河南省发票查询真伪查询系统
  • 电子税务局领取纸质发票的步骤
  • 一般纳税人提供公共交通运输服务免征增值税
  • 政府主管部门对企业检查要求
  • 一般纳税人申请流程
  • 契税维修基金交给谁
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设