ThinkPHP 3.2.2实现事务操作的方法
本文实例讲述了ThinkPHP3.2.2实现事务操作的方法。分享给大家供大家参考,具体如下:
手册里说得非常清楚:
5.3.19事务支持
ThinkPHP提供了单数据库的事务支持,如果要在应用逻辑中使用事务,可以参考下面的方法:
启动事务:
$User->startTrans()
提交事务:
$User->commit()
事务回滚:
$User->rollback()
事务是针对数据库本身的,所以可以跨模型操作的。
例如:
//在User模型中启动事务 $User->startTrans() //进行相关的业务逻辑操作 $Info=M("Info");//实例化Info对象 $Info->save($User);//保存用户信息 if(操作成功){ //提交事务 $User->commit() }else{ //事务回滚 $User->rollback() }
IndexController.class.php:
startTrans(); $result=M('feehistory')->add($data); $result1=$result2=true; if(!empty($result)){ $regdelData['level']='111'; $result1=M('regdel')->add($regdelData); $regData['level']='101'; $result2=M('reg')->where("registryCode='13693536752-SJB-HUAX-12345678'")->save($regData); } if(!empty($result)&&!empty($result1)&&!empty($result2)){ M()->commit(); //$this->success('事物提交',__ROOT__); echo'事物提交'; }else{ M()->rollback(); //$this->error('事物回滚',__ROOT__); echo'事物回滚'; } } }
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。