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

PDO::beginTransaction

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

PDO :: beginTransaction - 启动一个事务

描述

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

关闭自动提交模式。在自动提交模式关闭时,在通过调用PDO :: commit()结束事务之前,不会提交通过PDO对象实例对数据库所做的更改。调用PDO :: rollBack()将回滚对数据库的所有更改并将连接返回到自动提交模式。

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

返回值

返回TRUE成功或返回FALSE失败。

错误/异常

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

注意:即使不是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 */
?>
代码语言:txt
复制
 © 1997–2017 The PHP Documentation Group

根据知识共享署名许可证v3.0或更高版本授权。

扫码关注腾讯云开发者

领取腾讯云代金券