- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在脚本上运行了十几个更新语句,但有些更新不会发生,我需要知道为什么以及如何解决这种情况。
我有这段代码:
foreach($clis as $c => $cli)
{
//... do some stuff
foreach($emails as $e)
{
$Mailqueue = $this->em->getRepository('Sendsys\Entity\Mailqueue')->findBy(array("email" => $e,"status" => "P"));
foreach($Mailqueue as $queue)
{
$queue->setStatus('S');
$this->em->persist($queue);
}
}
$this->em->flush(); //entity manager is retrieved before that
}
这基本上是通过一个(有点大的)表来将状态为“P”的电子邮件更新为“S”,这些电子邮件位于 $emails 数组的列表中。
我曾尝试将 doctrine 的 ExecuteUpdate 与准备好的语句一起使用,而不是每次都检索和保留一个实体,但它会导致完全相同的问题。
更多细节:
即使邮件发送功能被注释掉也会出现这个问题
我知道正在发送所有电子邮件(未注释时)并且脚本正在生成所有更新语句,我在测试 ExecuteUpdate 时输出了它们
我知道更新正在到达 Postgres,因为有些行确实更新了,如果我刷新,这些行将随机更新,直到没有剩余为止
我不能事后更新所有内容,我需要知道脚本在何处停止以防失败。
编辑
这与理论无关,我直接连接到数据库并在循环中运行以下语句:
$dbh->setAttribute(\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION);
$stmt = $dbh->prepare("UPDATE mailqueue SET status = 'S' WHERE status = :status AND email LIKE :mail");
$stmt->execute(array( ':status' => 'P', ':mail' => $e ));
echo $stmt->rowCount();
最佳答案
更新语句仅在 $this->em->flush() 的末尾运行;这是唯一告诉 Doctrine 开始 SQL 事务的操作,如果您需要在此之前执行更新,只需调用 flush 方法即可。
在冲洗前的处理过程中,更改保留在链接到管理器的实体中。
关于php - Doctrine/PostgreSQL 没有在我的脚本上运行每个更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35892184/
我正在使用 Gunicorn 为 Django 应用程序提供服务,它工作正常,直到我将其超时时间从 30 秒更改为 900000 秒,我不得不这样做,因为我有一个用例需要上传和处理一个巨大的文件(过程
我有一个带有非常基本的管道的Jenkinsfile,它可以旋转docker容器: pipeline { agent { dockerfile { args '-u root' } } stag
在学习 MEAN 堆栈的过程中,我遇到了一个问题。每当我尝试使用 Passport 验证方法时,它都不会返回任何响应。我总是收到“localhost没有发送任何数据。ERR_EMPTY_RESPONS
在当今的大多数企业堆栈中,数据库是我们存储所有秘密的地方。它是安全屋,是待命室,也是用于存储可能非常私密或极具价值的物品的集散地。对于依赖它的数据库管理员、程序员和DevOps团队来说,保护它免受所
是否可以创建像图片上那样的边框?只需使用 css 边框属性。最终结果将是没 Angular 盒子。我不想添加额外的 html 元素。我只想为每个 li 元素添加 css 边框信息。 假设这是一个 ul
我是一名优秀的程序员,十分优秀!