如何中止 PrePersist 函数上的查询执行?

问题描述 投票:0回答:1

我目前正在使用 sonata adminDoctrine ORM 开发 synfomy 4.2 项目。

当某些条件设置为 true 时,我想中止查询执行,例如,如果我想插入一个新产品,但该产品由于某种原因缺少参数价格,那么我想中止该查询并设置闪现消息,让用户知道该产品无法创建,因为缺乏价格。

我已经完成了研究,但找不到与我的问题相关的任何内容,我确实知道此功能必须应用于实体上的 PrePersist 函数。

我一直被这样的事情搞得头晕目眩。

/**
* @ORM\PrePersist
*/
public function prePersist(LifecycleEventArgs $args)
{
    $em = $args->getEntityManager("App\Milenio\VersionsControlBundle\Entity\Plugins");
    $em->getConnection();
    $em->flush();
    $em->clear();
}

但是当然这没有任何作用,我仍然导致了一个明显的 SQL 异常。

我知道有一些方法可以告诉奏鸣曲管理员进行输入,但在我的特殊情况下,这不会成功。

php symfony doctrine sonata-admin
1个回答
0
投票

强制用户填写价格,或者只是使价格不可为空,并在控制器中捕获错误,然后向用户发送消息,这些东西是更干净的解决方案并且不需要,这不是更有意义吗?听众。此外,我认为您不能刷新预持久,也许实体管理器->回滚或实体管理器分离就是您正在寻找的

© www.soinside.com 2019 - 2024. All rights reserved.