ThinkPHP 3.2.2实现事务操作的方法


Posted in PHP onMay 05, 2017

本文实例讲述了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框架的PHP程序设计有所帮助。

PHP 相关文章推荐
php skymvc 一款轻量、简单的php
Jun 28 PHP
浅析PHP substr,mb_substr以及mb_strcut的区别和用法
Jun 21 PHP
PHP实现变色验证码实例
Jan 06 PHP
php创建sprite
Feb 11 PHP
php读取目录所有文件信息dir示例
Mar 18 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(十六)
Jun 30 PHP
Zend Framework教程之Application和Bootstrap用法详解
Mar 10 PHP
PHP环境搭建(php+Apache+mysql)
Nov 14 PHP
[原创]PHP实现字节数Byte转换为KB、MB、GB、TB的方法
Aug 31 PHP
PHP封装类似thinkphp连贯操作数据库Db类与简单应用示例
May 08 PHP
PHP+redis实现微博的拉模型案例详解
Jul 10 PHP
Laravel 错误提示本地化的实现
Oct 22 PHP
PHP实现Session入库/存入redis的方法
May 04 #PHP
ThinkPHP中Widget扩展的两种写法及调用方法详解
May 04 #PHP
PHP+jQuery实现滚屏无刷新动态加载数据功能详解
May 04 #PHP
PHP调用Mailgun发送邮件的方法
May 04 #PHP
PHP实现图片的等比缩放和Logo水印功能示例
May 04 #PHP
Yii2数据库操作常用方法小结
May 04 #PHP
Yii2中添加全局函数的方法分析
May 04 #PHP
You might like
解析PHP中$_FILES的使用以及注意事项
2013/07/05 PHP
php mysql PDO 查询操作的实例详解
2017/09/23 PHP
禁止刷新,回退的JS
2006/11/25 Javascript
Node.js实战 建立简单的Web服务器
2012/03/08 Javascript
jquery验证表单中的单选与多选实例
2013/08/18 Javascript
JS实现图片翻书效果示例代码
2013/09/09 Javascript
QQ空间顶部折页撕开效果示例代码
2014/06/15 Javascript
javascript数组去重方法汇总
2015/04/23 Javascript
js组件SlotMachine实现图片切换效果制作抽奖系统
2016/04/17 Javascript
JavaScript绑定事件监听函数的通用方法
2016/05/14 Javascript
AngularJS中的表单简单入门
2016/07/28 Javascript
用nodejs的实现原理和搭建服务器(动态)
2016/08/10 NodeJs
浅谈angular懒加载的一些坑
2016/08/20 Javascript
jQuery使用getJSON方法获取json数据完整示例
2016/09/13 Javascript
jQuery模拟实现的select点击选择效果【附demo源码下载】
2016/11/09 Javascript
jQuery实现圣诞节礼物传送(花式轮播)
2016/12/25 Javascript
Vue自定义过滤器格式化数字三位加一逗号实现代码
2018/03/23 Javascript
vant组件中 dialog的确认按钮的回调事件操作
2020/11/04 Javascript
python批量生成本地ip地址的方法
2015/03/23 Python
Python的time模块中的常用方法整理
2015/06/18 Python
python3之微信文章爬虫实例讲解
2017/07/12 Python
特征脸(Eigenface)理论基础之PCA主成分分析法
2018/03/13 Python
pytorch 数据集图片显示方法
2018/07/26 Python
详解python--模拟轮盘抽奖游戏
2019/04/12 Python
Python常见数据类型转换操作示例
2019/05/08 Python
Jupyter notebook快速入门教程(推荐)
2020/05/18 Python
实例讲解CSS3中的box-flex弹性盒属性布局
2016/06/09 HTML / CSS
类、抽象类、接口的差异
2016/06/13 面试题
如何判断一段程序是由C 编译程序还是由C++编译程序编译的
2013/08/04 面试题
大学毕业生文采飞扬的自我鉴定
2013/12/03 职场文书
质量提升方案
2014/06/16 职场文书
离职证明范本(5篇)
2014/09/19 职场文书
学生评语集锦
2015/01/04 职场文书
小学教师师德师风自我评价
2015/03/04 职场文书
大学文艺委员竞选稿
2015/11/19 职场文书
vue+elementui 实现新增和修改共用一个弹框的完整代码
2021/06/08 Vue.js