教义集合的重新征集收集表格

时间:2015-10-06 11:48:40

标签: forms symfony doctrine-orm arraycollection

首先感谢你的帮助。

这是我的实体:

class Salon { 
/**
 * @ORM\ManyToMany(targetEntity="Screenfony\DemoBundle\Entity\Exposant", cascade={"persist"})
 */
private $exposants;
第二个:

class Exposant{
/**
 * @var integer
 *
 * @ORM\Column(name="id", type="integer")
 * @ORM\Id
 * @ORM\GeneratedValue(strategy="AUTO")
 */
private $id;

我想为一个Exposant创建一个表单,他将能够看到他的沙龙的集合(添加和删除一些)。

首先,我坚持要求获得暴露者的所有沙龙。 我试过但没有奏效:

    $exposant = $this   ->getDoctrine()
                      ->getManager()
                      ->getRepository('ScreenfonyDemoBundle:Exposant')
                      ->findOneBy(array('user' => $id)); 

    $exposant_id = $exposant->getId();

    $salons = $this ->getDoctrine()
                    ->getManager()
                    ->getRepository('ScreenfonyDemoBundle:Salon');

    $my_salons = new \Doctrine\Common\Collections\ArrayCollection(); 

    foreach ($salons as $salon) {
        if($salon->getExposants()->contains($exposant_id)){
            $mes_salons->add($salon);
        }
    }

然后我想在表单中添加结果并使用新的展示沙龙来处理请求。

感谢您的帮助

1 个答案:

答案 0 :(得分:0)

在你的类曝光中,它缺少创建中间表exposant_salon的多对多关系:

class Exposant{
/**
 * @var integer
 *
 * @ORM\Column(name="id", type="integer")
 * @ORM\Id
 * @ORM\GeneratedValue(strategy="AUTO")
 */
private $id;

/**
 * @ORM\ManyToMany(targetEntity="Screenfony\DemoBundle\Entity\salon", inversedBy="exposants", cascade={"persist"})
 * @ORM\JoinTable(name="exposant_salon",
 *      joinColumns={@ORM\JoinColumn(name="id_exposant", referencedColumnName="id")},
 *      inverseJoinColumns={@ORM\JoinColumn(name="id_salon", referencedColumnName="id")}
 * )
 */
private $salons;

在实体曝光中创建方法getSalons()之后:

public function getSalons()
{
    return $this->salons;
}

恢复暴露沙龙的行为如下:

$my_salons = $exposant->getSalons();