Thinkphp 跨模型实现事务回滚

Posted qizishuo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Thinkphp 跨模型实现事务回滚相关的知识,希望对你有一定的参考价值。

数据库中数据表类型Innodb

controller 层文件

$m = M();
$m->startTrans();

$shop = $m->query(‘SELECT * FROM `think_shop` WHERE id=‘.$custom[‘shop_id‘].‘ FOR UPDATE‘);
$shop = $shop[‘0‘];
$ret1 = D(‘Transaction‘)->goodsNum(参数1,参数2, $m);
if(!$ret1) {
  $m->rollback();
} else {
  $m->commit();

}

model 层文件

public function goodsNum(参数1,参数2, $m) {

操作....

//$ret1 = $m->execute("UPDATE `think_shop_goods` SET `stock` = stock-".$goodsNum[$key]." WHERE goods_id=".$goodsId." AND shop_id = ".$shop[‘id‘]);

 

//判断结果 返回true 或者 false

if(! $ret1) {
  return false;
} else {
  return true;

}
}

 

注意model层不需commit和rollback












以上是关于Thinkphp 跨模型实现事务回滚的主要内容,如果未能解决你的问题,请参考以下文章

ThinkPHP实现事务回滚示例代码

ThinkPHP 实现数据库事务回滚示例代码

ThinkPHP5.0 模型类事务性操作

浅谈ThinkPH5.0和5.1的反序列化利用链分析

thinkphp对180万数据批量更新支持事务回滚

ThinkPHP求助,关联模型查询如何跨表多条件查询