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中去除换行解决办法小结(PHP_EOL)
Nov 27 PHP
php变量范围介绍
Oct 15 PHP
浅析PHP递归函数返回值使用方法
Feb 18 PHP
PHP连接sql server 2005环境配置及问题解决
Aug 08 PHP
PHP常用编译参数中文说明
Sep 27 PHP
PHP的Socket通信之UDP通信实例
Jul 02 PHP
Zend Framework教程之请求对象的封装Zend_Controller_Request实例详解
Mar 07 PHP
如何正确配置Nginx + PHP
Jul 15 PHP
PHP基于Closure类创建匿名函数的方法详解
Aug 17 PHP
laravel 获取当前url的别名方法
Oct 11 PHP
Yii框架组件的事件机制原理与用法分析
Apr 07 PHP
PHP变量的作用范围实例讲解
Dec 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
解决ThinkPHP下使用上传插件Uploadify浏览器firefox报302错误的方法
2015/12/18 PHP
ThinkPHP5框架实现简单的批量查询功能示例
2018/06/07 PHP
jQuery总体架构的理解分析
2011/03/07 Javascript
chrome原生方法之数组
2011/11/30 Javascript
IE6浏览器下resize事件被执行了多次解决方法
2012/12/11 Javascript
解析window.open的使用方法总结
2013/06/19 Javascript
JavaScript制作的可折叠弹出式菜单示例
2014/04/04 Javascript
javascript模拟post提交隐藏地址栏的参数
2014/09/03 Javascript
JavaScript组合拼接字符串的效率对比测试
2014/11/06 Javascript
jQuery实用技巧必备(下)
2015/11/03 Javascript
JavaScript高级教程5.6之基本包装类型(详细)
2015/11/23 Javascript
JavaScript笔记之数据属性和存储器属性
2016/03/31 Javascript
js数组与字符串常用方法总结
2017/01/13 Javascript
在 webpack 中使用 ECharts的实例详解
2018/02/05 Javascript
json对象及数组键值的深度大小写转换问题详解
2018/03/30 Javascript
vue 之 css module的使用方法
2018/12/04 Javascript
微信小程序实现单选选项卡切换效果
2020/06/19 Javascript
Openlayers测量距离与面积的实现方法
2020/09/25 Javascript
vue 解决provide和inject响应的问题
2020/11/12 Javascript
Python 多进程并发操作中进程池Pool的实例
2017/11/01 Python
python代码过长的换行方法
2018/07/19 Python
Python符号计算之实现函数极限的方法
2019/07/15 Python
django多个APP的urls设置方法(views重复问题解决)
2019/07/19 Python
Python自动化完成tb喵币任务的操作方法
2019/10/30 Python
python绘制BA无标度网络示例代码
2019/11/21 Python
Python使用gluon/mxnet模块实现的mnist手写数字识别功能完整示例
2019/12/18 Python
keras读取h5文件load_weights、load代码操作
2020/06/12 Python
python模拟点击玩游戏的实例讲解
2020/11/26 Python
一个SQL面试题
2014/08/21 面试题
职工趣味运动会方案
2014/02/10 职场文书
艺术节主持词
2014/04/02 职场文书
课例研修方案
2014/05/31 职场文书
班级出游活动计划书
2014/08/15 职场文书
农村老人去世追悼词
2015/06/23 职场文书
重阳节简报
2015/07/20 职场文书
Python 匹配文本并在其上一行追加文本
2022/05/11 Python