当前位置: 首页 > 编程笔记 >

ThinkPHP 3.2.2实现事务操作的方法

郭修平
2023-03-14
本文向大家介绍ThinkPHP 3.2.2实现事务操作的方法,包括了ThinkPHP 3.2.2实现事务操作的方法的使用技巧和注意事项,需要的朋友参考一下

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

 类似资料:
  • 本文向大家介绍python实现redis三种cas事务操作,包括了python实现redis三种cas事务操作的使用技巧和注意事项,需要的朋友参考一下 cas全称是compare and set,是一种典型的事务操作。 简单的说,事务就是为了存取数据库中同一数据时不破坏操作的隔离性和原子性,从而保证数据的一致性。 一般数据库,比如MySql是如何保证数据一致性的呢,主要是加锁,悲观锁。比如在访问数

  • 使用事务处理的话,需要数据库引擎支持事务处理。比如 MySQL 的 MyISAM 不支持事务处理,需要使用 InnoDB 引擎。 使用 transaction 方法操作数据库事务,当发生异常会自动回滚,例如: 自动控制事务处理 Db::transaction(function(){ Db::name('user')->find(1); Db::name('user')->delet

  • 使用事务处理的话,需要数据库引擎支持事务处理。比如 MySQL 的 MyISAM 不支持事务处理,需要使用 InnoDB 引擎。 使用 transaction 方法操作数据库事务,当发生异常会自动回滚,例如: 自动控制事务处理 Db::transaction(function(){ Db::name('user')->find(1); Db::name('user')->delet

  • 使用事务处理的话,需要数据库引擎支持事务处理。比如 MySQL 的 MyISAM 不支持事务处理,需要使用 InnoDB 引擎。 最简单的方式是使用 transaction 方法操作数据库事务,当闭包中的代码发生异常会自动回滚,例如: Db::transaction(function () { Db::table('think_user')->find(1); Db::table(

  • 本文向大家介绍thinkphp3.2.2实现生成多张缩略图的方法,包括了thinkphp3.2.2实现生成多张缩略图的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了thinkphp3.2.2实现生成多张缩略图的方法。分享给大家供大家参考。 具体实现方法如下: 调用方法: 这里要注意thinkphp3.2.2并没有UploadFile,UploadImage 类,需要从扩展包里提取出来

  • 事务操作包含3个接口:newTransaction,transactionGet ,transactionCommit Transaction newTransaction() 功能 初始化transaction操作,Transaction内保证事务原子性 方法返回值 Transaction对象记录事务信息 GetResult transactionGet(Transaction transact