ThinkPHP 3.2.2实现事务操作的方法
2017-05-05 08:50
796 查看
本文实例讲述了ThinkPHP 3.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:
<?php namespace SMS\Controller; use Think\Controller; class IndexController extends Controller { public function index(){ $data['operator'] = 'Testss'; M()->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相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
您可能感兴趣的文章:
相关文章推荐
- thinkphp3.2.2实现生成多张缩略图的方法
- thinkphp3.2.2实现生成多张缩略图的方法
- ThinkPHP3.2.2实现持久登录(记住我)功能的方法
- ThinkPHP3.2.2实现持久登录(记住我)功能的方法
- php使用PDO事务配合表格读取大量数据插入操作实现方法
- ThinkPHP实现图片上传操作的方法详解
- ThinkPHP3.1.2中DbOracle.class.php不能实现事务处理的解决方法
- thinkphp3.2 中用S方法实现 用户定时操作
- 利用ASP实现事务处理的方法
- 利用ASP实现事务处理的方法
- 另外一个实现事务提交、回滚的方法
- 自己写的实现数据库事务的简单方法ExecuteSqlTran()
- 在VB环境中操作三维模型的实现方法
- 利用ASP实现事务处理的方法
- 利用ASP实现事务处理的方法
- 利用ASP实现事务处理的方法
- 利用ASP实现事务处理的方法
- 利用ASP实现事务处理的方法
- delphi中实现用字符串表示并操作控件的方法。
- 利用ASP实现事务处理的方法