- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在使用 Symfony2 和 Doctrine2 的项目中遇到问题,因为我无法在刷新后操纵查询的顺序...
我有 2 个具有 OneToOne 双向关系的实体:用户和团队这是一个例子来说明我所面临的情况:
RedTeam have a team manager (user) : Mark
GreenTeam have a team manager (user): Jack
如果我把 Redteam 的团队经理换成 Jack 那么我应该这样做
RedTeam have a team manager : Jack
GreenTeam have a team manager : null
这是我的实体类,其中包含我制作的 setter
用户:
class User {
/**
* @ORM\OneToOne(targetEntity="Vci\MainBundle\Entity\Team" , mappedBy="teamManager")
*/
protected $managedTeam;
public function setManagedTeam(Team $managedTeam = null) {
if ($managedTeam != null && $this->managedTeam !=null ) {
$this->managedTeam->setTeamManager(null);
}
$this->managedTeam = $managedTeam ;
return $this;
}
}
团队
class Team {
/**
* @ORM\OneToOne(targetEntity="Vci\MainBundle\Entity\User" , inversedBy="managedTeam")
* @ORM\JoinColumn(nullable=true)
*/
protected $teamManager;
public function setTeamManager(User $teamManager = null) {
if ($teamManager != null && $this->teamManager!=null) {
$this->teamManager->setTeamManaged(null);
}
$this->teamManager = $teamManager;
if ($this->teamManager != null) {
$this->teamManager->setTeamManaged($this);
}
return $this;
}
}
这是我 Controller 的一部分
if ($request->getMethod() == 'POST') {
$form->bind($request); // the setter is called here
if ($form->isValid()) {
$teamManager = $this->get('vci_main.teammanager');
$teamgreen = $teamManager->findById(2);
$teamred = $teamManager->findById(1);
//the 2 teams are perfectly changed
//save in database
$this->em->flush(); // here is a flush and where the exception occure
通常贪婪队需要先更新以避免重复条目异常,但Nooodoctrine2总是直接从RedTeam开始..
这里是异常(exception):
An exception occurred while executing 'UPDATE Team SET teamManager_id = ? WHERE id = ?' with params [13, 1]:
SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry '13' for key 'UNIQ_64D209219EF091'
最佳答案
在一对一关系中,您必须先取消设置其他团队的团队经理。
即要做的事:
UPDATE team SET manager=:user_id WHERE id=:team_id
您需要首先执行此操作:
UPDATE team SET manager = null WHERE id=:user_id
为什么在团队更新之前没有触发器?触发器不是很好的做法,但它会简化您的问题。
关于php - doctrine2 查询同花后的顺序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20882490/
我用 redis 后端运行 celery。 我想在 centos 6.2 上运行 celery 花作为守护进程。 我知道花是 Tornado 应用程序,所以我应该使用一个进程来运行 Tornado 应
我在一台服务器上有几个项目,它们使用具有不同 BROKER_URL 的 celery 包。Flower 允许一个 BORKER_URL 作为命令选项: celery flower --broker=a
我正在使用芹菜和花卉。当我访问Flower中的“任务”标签时,我可以看到我的任务正在注册,甚至可以在“状态”列中看到“成功”标签以及所有内容。 但是,在“监视器”选项卡上,所有图形(“成功任务”,“失
我正在尝试创建一个有 5 个叶子的 css 花 - 没有任何有希望的尝试。我正在尝试创建什么:有 5 片叶子的 CSS 花,每片叶子可以有三种不同的状态(小、中、大)。我找到了 http://ross
如果我有一个变体,像这样: using my_variant = boost::variant; 有没有一种简单的方法可以将变体可以包含的类型提取到 Boost.Hana 元组中,以便满足以下条件:
调用 Flower API's /api/task/apply/* 只是挂起而没有返回结果,即使任务已根据 Web UI 处理并成功。 重现错误: # hangs even though task s
我有一个模板函数,默认情况下没有定义,但它由某些类型特化: template auto foo(bar &, const T &) -> void; template <> auto foo(bar
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我是一名优秀的程序员,十分优秀!