码迷,mamicode.com
首页 > Web开发 > 详细

Thinkphp 跨模型实现事务回滚

时间:2018-04-19 11:53:32      阅读:216      评论:0      收藏:0      [点我收藏+]

标签:数据库   function   round   commit   tar   文件   判断   cut   llb   

数据库中数据表类型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 跨模型实现事务回滚

标签:数据库   function   round   commit   tar   文件   判断   cut   llb   

原文地址:https://www.cnblogs.com/qizishuo/p/8880905.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!