首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PHP PDO事务自动rollBack

PHP PDO事务自动rollBack
EN

Stack Overflow用户
提问于 2013-05-19 03:04:48
回答 2查看 9.5K关注 0票数 7

我只是在我的一个应用程序上精炼一些代码,最近我从使用PHP ADODB库转换为PDO。在adodb中,一旦启动了一个事务,如果begin和commit命令之间的查询出现任何异常,它就会自动回滚。

PDO也是这样做的吗?如果一个方法有一个查询,它在PDO中的begin和commit之间失败,那么事务将自动回滚,还是需要隐式调用它?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-05-19 03:10:55

您必须自己调用rollback (并提交),PDO不会为您执行此操作。如下所示:

代码语言:javascript
复制
$pdo = new \PDO(/* ... */);

$pdo->beginTransaction();

try {
    // do stuff..
} catch(\Throwable $e) { // use \Exception in PHP < 7.0
    $pdo->rollBack();
    throw $e;
}

$pdo->commit();

然而,PDO将rollback any open transactions when a script ends

当脚本结束或连接即将关闭时,如果您有未完成的事务,

将自动回滚它。

因此,事务可能会回滚,这取决于您的应用程序(也许您有一个偶数侦听器,它将在某个地方为您提交?)。在发生异常的地方进行显式回滚可能是个好主意。

票数 19
EN

Stack Overflow用户

发布于 2014-01-17 22:05:04

来自http://www.php.net/manual/en/pdo.transactions.php

当脚本结束或连接即将关闭时,如果您有未完成的事务,

将自动回滚它。..。如果您没有显式地提交事务,那么就会假设出了问题,所以执行回滚是为了保证数据的安全。

不过,在出现错误时显式回滚事务是一种很好的做法。有关更多详细信息,请参阅此问题:If an PHP PDO transaction fails, must I rollback() explicitely?

票数 14
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16627942

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档