位置: 编程技术 - 正文

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)

  • 印花税计算是含增值税吗
  • 税务专业是什么学位
  • 固定资产折旧计算公式
  • 经营活动产生的净现金流量计算公式
  • 电子设备残值率的最新规定
  • 备用金为什么会变少
  • 印花税小于1元显示无需申报
  • 公允价值变动计入其他综合收益
  • 药店商品进销差价
  • 延迟交款收息做什么科目?
  • 单位员工去外地上班
  • 非生产用设备及器具
  • 私人帐户可以给别人用吗
  • 预缴税款后怎么开票
  • 文化传媒行业会计
  • 保险费可以抵扣嘛
  • 三代手续费入账
  • 公司当年福利费没有用到限额,可以按照14%计提税前扣除吗?
  • 三公经费包括哪些支出
  • 油卡充值属于什么行业
  • 宣传活动物资
  • 应付账款周转率越高越好吗
  • 专票开票银行一定要对吗
  • 天然气税费
  • 免征增值税转入什么科目
  • 个体户如何办税
  • 生产车间的窗帘怎么处理
  • 电脑经常重新启动是什么原因
  • 固定资产一次性扣除后第二年账务处理
  • 不能抵扣的费用
  • 监事会职权范围是什么
  • 银行退回手续费的账务处理
  • php加载
  • linux系列
  • 电压是什么量
  • 如何利用命令符复制文件
  • 生产车间闲置的固定资产
  • 网络通信的整个流程
  • 汇算清缴补交的所得税怎么记帐
  • php设计网页
  • yii框架官网
  • 未完待续百度百科
  • uniapp scroll-view基础用法
  • 公链dapp
  • 计算机视觉opencv项目简单代码
  • effective c++ github
  • 递延所得税资产和递延所得税负债
  • 土地使用权被政府收回要交个税吗
  • 纳税人增值税专用发票票面价税合计最多开多少金额
  • 财务费用包含了利息费用吗
  • 独资合伙企业的特点
  • 职工薪酬包括哪些应如何计算
  • 机票会计代理如何做
  • 事业单位非税收入帐务处理
  • 用于集体福利的进项税额怎么处理
  • 房租增值税专票税点
  • 净资产总计等于什么
  • 公司的残保金是分摊到员工身上的吗
  • mysql外键怎么写
  • jmeter怎么连接数据库
  • win8无internet访问权限怎么解决
  • CentOS 6.2(32位/64位) 安装步骤图文详解
  • win7系统笔记本怎么连接wifi
  • win10hdmi转vga显示器没反应
  • ubuntu搭建安卓环境
  • js中事件的三要素
  • bash 数值比较
  • 分享两句话
  • javascript的
  • iframe transparent透明背景方法
  • 详细解读了
  • javascriptcsdn
  • 国家电子税务局登录入口
  • 小规模纳税人租金收入不超过30万
  • 你家预收租金到哪里去了
  • 自然人扣缴端初始密码
  • 长沙税务注销公示期是多久
  • 武汉办房产证契税怎么交
  • 耕地占用税是土地增值税扣除项目吗
  • 国网成都市局和绵阳市局的区别?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设