首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >信条DBAL事务

信条DBAL事务
EN

Stack Overflow用户
提问于 2011-07-23 14:11:00
回答 2查看 4.7K关注 0票数 3

我真的不了解如何在DBAL中进行事务处理

我有以下脚本,它根据行的id更新一列。我放了一个不存在于表中的假id (因此使得更新无法发生),但是尽管它是一个事务,第一次更新还是被提交了。我预计如果其中一个事务失败,所有事务都会失败。

代码语言:javascript
复制
 $conn -> beginTransaction();
   try{
       $try = $conn->prepare("update table set column = '123' where id = 0"); //column exists
       $try->execute();
       $try = $conn->prepare("update table set column = '123' where id = 1"); //column exists
       $try->execute();
       $try = $conn->prepare("update table set column = '123' where id = 120"); //column does not exists
       $try->execute();

       $try = $conn->commit();
   }
   catch(Exception $e) {
       $try = $conn->rollback();
       throw $e;
   }

预期结果,没有更新,因为id = 120的行不存在真实结果,除了不存在的行之外,所有行都被更新。

我提前道歉,但面向对象编程对我来说仍然是南极洲。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-01-27 22:13:38

我知道这个问题很老了,所以如果将来有人遇到类似的问题,我会稍微解释一下,因为这种行为不是错误。

代码语言:javascript
复制
$try = $conn->prepare("update table set column = '123' where id = 120"); //column does not exists
$try->execute();

在这里,update条件引用了一个不存在的列,因此查询不会失败,它将更新0(零)行;在Doctrine中,受影响的行数由execute()方法返回。

您可以抛出一个异常来触发回滚。

代码语言:javascript
复制
$try = $conn->prepare("update table set column = '123' where id = 120"); //column does not exists
$affected = $try->execute();
if ($affected == 0) {
  throw new Exception('Update failed');
}
票数 3
EN

Stack Overflow用户

发布于 2011-07-23 15:39:50

此代码仅在抛出异常时回滚事务。

当更新不成功时,它返回false,而不是异常。

您可以无一例外地尝试:

代码语言:javascript
复制
$try = $conn->commit();
if (!$try) {
   $conn->rollback();
}

或者当result为false时抛出异常。

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

https://stackoverflow.com/questions/6798613

复制
相关文章

相似问题

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