0

Doctrine2 と関連付けを使い始めましたが、すべての側面を理解しているわけではありません。

私は2つのphpクラスを持っています:

class User extends BaseUser
{     
    protected $id;

    protected $team;

/**
 * Get id
 *
 * @return integer $id
 */
public function getId()
{
    return $this->id;
}

public function setId($id) {
    $this->id = $id;
}

public function getTeam() {
    return $this->team;
}

public function setTeam($team) {
    $this->team = $team;
}


}

/**
 * Team
 *
 * @ORM\Table(name="basket__team")
 * @ORM\Entity(repositoryClass="Tperroin\BasketBundle\Entity\TeamRepository")
 */
class Team
{
/**
 * @var integer
 *
 * @ORM\Column(name="id", type="integer")
 * @ORM\Id
 * @ORM\GeneratedValue(strategy="AUTO")
 */
private $id;

/**
 * @var string
 *
 * @ORM\Column(name="categorie", type="string", length=255)
 */
private $categorie;

/**
 * @var string
 *
 * @ORM\ManyToMany(targetEntity="Application\Sonata\UserBundle\Entity\User", inversedBy="users", cascade={"persist"})
 * @ORM\JoinTable(name="basket__team_user_coach")
 */
private $coachs;

/**
 * @var string
 *
 * @ORM\ManyToMany(targetEntity="Application\Sonata\UserBundle\Entity\User", inversedBy="users", cascade={"persist"})
 * @ORM\JoinTable(name="basket__team_user_player")
 */
private $players;

/**
 * @var string
 *
 * @ORM\Column(name="level", type="string", length=255)
 */
private $level;

私の問題は、ユーザーが新しいプロファイルを作成すると、関連付けが作成されないことです。

だから私は PostPersist を使って User クラスにこの関数を持っています:

public function addTeam(LifecycleEventArgs $args) { 

    $entity = $args->getEntity(); 
    $em = $args->getEntityManager();

    $player = $this->getTeam();

    $player->setPlayers(array($entity));

    $em->persist($player);
    $em->flush();
}

それは機能しますが、1人のユーザーに対してのみ、私の関数は挿入クエリの前に削除クエリを生成します。

この種の問題の解決策はありますか?

ありがとうございました

4

1 に答える 1