实体用户
class User {
/**
* @var integer
*
* @ORM\Column(name="id", type="integer", nullable=false)
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
protected $id;
...
/**
* @ORM\ManyToMany(targetEntity="Controleitor\Model\Entity\Account", mappedBy="user")
*/
protected $userAccount;
public function __construct() {
$this->userAccount = new \Doctrine\Common\Collections\ArrayCollection();
}
public function getUserAccount() {
return $this->userAccount;
}
...
}
实体帐户
class Account{
/**
* @var integer
*
* @ORM\Column(name="id", type="integer", nullable=false)
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $id;
/**
*
* @ORM\ManyToMany(targetEntity="JasUser\Model\Entity\User", inversedBy="userAccount")
* @ORM\JoinTable(name="user_has_account",
* joinColumns={@ORM\JoinColumn(name="idAccount", referencedColumnName="id")},
* inverseJoinColumns={@ORM\JoinColumn(name="idUser", referencedColumnName="id")}
* )
*/
private $user;
public function __construct(array $options = null) {
$this->user = new \Doctrine\Common\Collections\ArrayCollection();
}
...
}
测试:
$user = $this->entityManager->getRepository('User')->findOneById($id);
$user->getUserAccount()->add($account);
$this->entityManager->persist($account);
$this->entityManager->flush();
$id = $entity->getId();
它获取用户,userAccount并在数据库中插入新记录帐户,但它不会在user_has_account表中添加记录,以便用户和帐户之间的多人关联像我期待的那样添加方法..
答案 0 :(得分:0)
看起来你的关系已经owning/inverse sides了。
拥有方必须使用OneToOne,ManyToOne或ManyToMany映射声明的inversedBy属性。 inversedBy属性包含反面的关联字段的名称。
忽略仅对关联的反面进行的更改。确保更新双向关联的两面(或至少从Doctrine的角度更新所有方)
这可能有点烦人。
首选解决方案是仅在内部触摸收藏集。因此,不要让您的调用代码执行$user->getUserAccount()->add($account)
,而是按照以下方式实现:
<?php
class Account {
// ...
public function addUser($user){
$this->users->add($user);
}
}
class User {
// ...
public function addAccount($account){
// relation must be added from the owning side
$account->addUser($this);
}
}