首先感谢你的帮助。
这是我的实体:
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);
}
}
然后我想在表单中添加结果并使用新的展示沙龙来处理请求。
感谢您的帮助
答案 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();