首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

PDO::rollBack

(PHP 5 >= 5.1.0, PHP 7, PECL pdo >= 0.1.0)

PDO :: rollBack - 回退任务

描述

代码语言:javascript
复制
public bool PDO::rollBack ( void )

回退当前任务,由PDO :: beginTransaction()启动。

如果数据库设置为自动提交模式,则此功能在回退事务后将恢复自动提交模式。

当数据库定义语言(DDL)语句(如DROP TABLE或CREATE TABLE)在事务内发出时,某些数据库(包括MySQL)会自动发出隐式COMMIT。隐式COMMIT将阻止您回退事务边界内的任何其他更改。

返回值

成功则返回TRUE或失败时返回FALSE

错误/异常

如果没有活动事务,则抛出PDOException。

注意:即使不是PDO::ATTR_ERRMODE属性,也会引发异常PDO::ERRMODE_EXCEPTION

示例

示例#1回退事务

以下示例开始一个事务并在回退更改之前发出两条修改数据库的语句。但是,在MySQL中,DROP TABLE语句会自动提交事务,以便事务中的任何更改都不会回退。

代码语言:javascript
复制
<?php
/*?Begin?a?transaction,?turning?off?autocommit?*/
$dbh->beginTransaction();

/*?Change?the?database?schema?and?data?*/
$sth?=?$dbh->exec("DROP?TABLE?fruit");
$sth?=?$dbh->exec("UPDATE?dessert
????SET?name?=?'hamburger'");

/*?Recognize?mistake?and?roll?back?changes?*/
$dbh->rollBack();

/*?Database?connection?is?now?back?in?autocommit?mode?*/
?>

扩展内容

  • PDO :: beginTransaction() - 启动一个事务
  • PDO :: commit() - 提交一个事务

← PDO::quote

PDO::setAttribute →

扫码关注腾讯云开发者

领取腾讯云代金券

http://www.vxiaotou.com