我目前正在使用 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异常。
我知道有一些方法可以让Sonata管理员进行必要的输入,但是在我的特殊情况下,并不能解决问题。
非常感谢。
答案 0 :(得分:0)
强迫用户填写价格,或者只是使价格不为零,并在控制器中捕获错误,然后向用户发送消息,这些都是更清洁的解决方案,而不是这样做没有任何意义。要求听众。此外,我不认为您可以使用prepersist刷新,也许您正在寻找entitymanager-> rollback或entitymanager detach