繁体   English   中英

Symfony2 ManyToMany具有属性

[英]Symfony2 ManyToMany with attributes

我正在尝试在一个视图中使用删除/更新/添加属性来管理多对多关系。

这是我的关系:用户可以说一些带有语言的语言。 因此,有一个表供用户,语言使用,而第三个表用于管理与级别的关系。

这是我的控制器:

    public function gererLangueAction(Request $request, User $user){
    $form = $this->createForm(new ajouterLangueFormType, $user);
    if ($request->getMethod() == 'POST') {
        $form->bind($request);
        if ($form->isValid()) {
            $em = $this->getDoctrine()->getManager();
            if(!empty($request->request->get("intranet_rh_gererlangue")['userLangues']))
                 foreach($request->request->get("intranet_rh_gererlangue")['userLangues'] as $langue)
                 {
                        $l = $em->getRepository('IntranetRhBundle:Langue')->findOneById($langue['langue']);
                        $userLangues = new UserLangue();
                        $userLangues->setUser($user);
                        $userLangues->setLangue($l);
                        $userLangues->setNiveau($langue['niveau']);
                        $user->addUserLangue($userLangues);
                        $em->persist($userLangues);
                }
            $em->flush();
            $this->get('session')->getFlashBag()->add('success', "Les langues de ". $user->getNom() ." ". $user->getPrenom() . " ont été modifiées avec succès !");
            return $this->redirect($this->generateUrl('intranet_rh_homepage'));
        }else
            $this->get('session')->getFlashBag()->add('danger', "Erreur de formulaire !");  
    }
    return $this->render('IntranetRhBundle:User:gererLangue.html.twig',array('user' => $user, 'form' => $form->createView()));
}

我的观点是正确的,我的JS允许我添加和删除,并且可以更新和删除一些已经存在的语言。

但是当我想添加一种语言时,我会收到以下消息:

“类型为Intranet \\ RhBundle \\ Entity \\ UserLangue的实体缺少为字段'user'分配的ID。此实体的标识符生成策略要求在调用EntityManager#persist()之前填充ID字段。如果要自动生成标识符,您需要相应地调整元数据映射。”

但是我不明白为什么,因为我在每堂课上都用我的学说注解:

对于UserLangue:

/**
* @ORM\Id
* @ORM\ManyToOne(targetEntity="Intranet\UserBundle\Entity\User", inversedBy="userLangues")
* @ORM\JoinColumn(name="user_id", referencedColumnName="id", nullable=false)
*/
private $user;

对于用户:

    /**
* @ORM\OneToMany(targetEntity="Intranet\RhBundle\Entity\UserLangue", mappedBy="user", cascade={"persist", "remove"}, orphanRemoval=true)
**/
private $userLangues;

具有添加和删除方法。 自3天以来我一直在研究此错误,但没有人遇到类似的错误...

您可以尝试在@ORM\\GeneratedValue(strategy="AUTO")中添加@ORM\\GeneratedValue(strategy="AUTO") ,但是将关系作为ID并不是一个很好的想法,我认为它甚至都无法工作。 尝试添加$ id参数并将关系设置为其他参数。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM