分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 技术分享

Thinkphp 跨模型实现事务回滚

发布时间:2023-09-06 01:50责任编辑:苏小强关键词:暂无标签

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

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

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved