PDO::beginTransaction讲解

今天小编就为大家分享一篇关于PDO::beginTransaction讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧。

PDO::beginTransaction

PDO::beginTransaction 启动一个事务(PHP 5 >= 5.1.0, PECL pdo >= 0.1.0)

说明

语法

bool PDO::beginTransaction ( void )

关闭自动提交模式。自动提交模式被关闭的同时,通过 PDO 对象实例对数据库做出的更改直到调用PDO::commit()结束事务才被提交。

调用PDO::rollBack()将回滚对数据库做出的更改并将数据库连接返回到自动提交模式。

包括 MySQL 在内的一些数据库,当发出一条类似 DROP TABLE 或 CREATE TABLE 这样的 DDL 语句时,会自动进行一个隐式地事务提交。

隐式地提交将阻止你在此事务范围内回滚任何其他更改。

返回值

成功时返回TRUE, 或者在失败时返回FALSE。

实例

回滚一个事务

下面例子在回滚此更改前开始一个事务并发出两条修改数据库的语句。

但在 MySQL 中,DROP TABLE 语句自动提交事务,使得在此事务中的任何更改都不会被回滚。

  1. <?php
  2. /* 开始一个事务,关闭自动提交 */
  3. $dbh->beginTransaction();
  4. /* 更改数据库架构及数据 */
  5. $sth = $dbh->exec("DROP TABLE fruit");
  6. $sth = $dbh->exec("UPDATE dessert
  7. SET name = 'hamburger'");
  8. /* 识别出错误并回滚更改 */
  9. $dbh->rollBack();
  10. /* 数据库连接现在返回到自动提交模式 */
  11. ?>