doctrine2刷新后查询顺序



我在使用Symfony2和Doctrine2的项目中遇到问题,因为我无法在刷新后操作查询的顺序。。。

我有两个具有OneToOne双向关系的实体:用户和团队这是一个例子来说明我所面临的情况:

RedTeam有一个团队经理(用户):Mark

GreenTeam有一个团队经理(用户):Jack

如果我把Redteam的团队经理换成Jack,那么我应该有

RedTeam有一位团队经理:Jack

GreenTeam有一个团队经理:空

这是我的实体类和我制作的setters

用户:

class User {
/**
* @ORMOneToOne(targetEntity="VciMainBundleEntityTeam" , 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 {
/**
* @ORMOneToOne(targetEntity="VciMainBundleEntityUser" , inversedBy="managedTeam")
* @ORMJoinColumn(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;
}
}

这是我的控制器的一部分

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

通常,greedteam需要首先更新以避免重复条目异常,但Nooo doctrine2总是直接从RedTeam开始。。

这里有一个例外:

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' 

在一对一关系中,必须先取消设置其他团队的团队经理。

I.E.要做的事:

UPDATE team SET manager=:user_id WHERE id=:team_id

您需要首先执行以下操作:

UPDATE team SET manager = null WHERE id=:user_id

为什么在团队更新之前没有触发器?触发器不是很好的练习,但它会简化你的问题。

相关内容

  • 没有找到相关文章

最新更新