我目前正在使用 sonata admin 和 Doctrine 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 异常。
我知道有一些方法可以告诉奏鸣曲管理员进行输入,但在我的特殊情况下,这不会成功。
强制用户填写价格,或者只是使价格不可为空,并在控制器中捕获错误,然后向用户发送消息,这些东西是更干净的解决方案并且不需要,这不是更有意义吗?听众。此外,我认为您不能刷新预持久,也许实体管理器->回滚或实体管理器分离就是您正在寻找的