首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何中止对PrePersist函数的查询执行?

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

Stack Overflow用户
提问于 2019-05-31 01:45:39
回答 1查看 84关注 0票数 0

我目前正在做一个使用sonata admin和Doctrine ORM的synfomy 4.2项目。

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

我已经做了我的研究,但我找不到任何与我的问题相关的东西,我知道必须在实体上的PrePersist函数中应用此功能。

我一直被这样的事情弄得头破血流。

代码语言:javascript
复制
/**
* @ORM\PrePersist
*/
public function prePersist(LifecycleEventArgs $args)
{
    $em = $args->getEntityManager("App\Milenio\VersionsControlBundle\Entity\Plugins");
    $em->getConnection();
    $em->flush();
    $em->clear();
}

但这当然没有什么作用,我仍然会导致一个明显的SQL异常。

我知道有一些方法可以让sonata admin输入所需的内容,但在我的特殊情况下,这是行不通的。

EN

回答 1

Stack Overflow用户

发布于 2019-05-31 07:53:42

强制用户填写价格,或者只是使价格不可为空,并在控制器中捕获错误,然后向用户发送消息,这不是更有意义吗?这些都是更干净的解决方案,不需要侦听器。此外,我不认为您可以刷新预持久化,也许entitymanager->rollback或entitymanager detach就是您正在寻找的

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

https://stackoverflow.com/questions/56383168

复制
相关文章

相似问题

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