Symfony在Bridge Entity Form中一次分配多个值

时间:2015-11-23 10:26:56

标签: php symfony doctrine-orm jquery-select2

我的实体之间存在以下关系。

Institute之间的一对多 - > InstituteCoursesCourses - >之间的一对多InstituteCourses

我避免在学校和课程之间做多次,因为我在instiutecourses实体中有更多的领域。

目前它运作良好,

    class Institutes {
        /**
        * @ORM\OneToMany(targetEntity="InstitutesCourses", mappedBy="institute", cascade={"all"})
        **/
        protected $instituteCourses;
    }
    class Courses {
        /**
         *
         * @ORM\OneToMany(targetEntity="InstitutesCourses", mappedBy="course", cascade={"all"}, orphanRemoval=true)
         */
        protected $instituteCourses;
    }

    class InstitutesCourses {
        /**
         * @ORM\ManyToOne(targetEntity="Institutes", inversedBy="instituteCourses")
         * @ORM\JoinColumn(name="institute_id", referencedColumnName="id")
         */
        protected $institute;

        /**
         * @ORM\ManyToOne(targetEntity="Courses", inversedBy="instituteCourses")
         * @ORM\JoinColumn(name="course_id", referencedColumnName="id")
         */
        protected $course;
  /**
     * @var boolean $isPrimary
     * @ORM\Column(name="is_primary", type="boolean", nullable=true)
     */
    protected $isPrimary;
   /**
     * @var boolean $verified
     * @ORM\Column(name="courses_verified", type="boolean", nullable=true)
     */
    protected $verified;
    /**
     * @var boolean $active
     * @ORM\Column(name="courses_active", type="boolean", nullable=true)
     */
    protected $active;
    /**
     *
     * @ORM\OneToMany(targetEntity="AcademicSessions", mappedBy="instituteCourse")
     */
    protected $academicSession;
    }

,表格是

 $builder->add('institute','entity', array(
                    'class'=>'PNC\InstitutesBundle\Entity\Institutes',
                    'property'=>'name',
                    'label' => 'Institute'
                )
            )
            ->add('course', 'entity', array(
                'class' => 'PNC\CoursesBundle\Entity\Courses',
                'property' => 'courseTitle',
                //'multiple' => true,
                'attr' => array(
                    'class' => 'form-control'
                )
            ))

现在,如果我想分配一个多学院的课程,我需要多次对所有新动作进行分配,我想要单独提交分配给一个学院的多个课程。当我在表单字段中设置multiple = true时。它给出了错误。

更新 -

class Institutes {

  /**
     * @ORM\OneToMany(targetEntity="NC\InstitutesBundle\Entity\InstitutesCourses", mappedBy="institute", cascade={"all"})
     * */
    protected $inst;
    protected $courses;


 public function __construct()
    {
        $this->inst = new ArrayCollection();
        $this->courses = new ArrayCollection();
    }

    // Important
    public function getCourses()
    {
        $courses = new ArrayCollection();

        foreach($this->inst as $ins)
        {
            $courses[] = $ins->getCourses();
        }
        return $courses;
    }

    // Important
    public function setCourses($courses)
    {


        foreach($courses as $c)
        {
            $po = new InstitutesCourses();
            $po->setCourse($c);
            $po->setInstitute($this);
            $this->addInst($po);
        }

    }

    // Important
    public function getCourse()
    {
        return $this;
    }
    // Important
    public function addInst($InstitutesCourses)
    {
        $this->inst[] = $InstitutesCourses;
    }
    // Important
    public function removeIns($InstitutesCourses)
    {
        return $this->inst->removeElement($InstitutesCourses);
    }

} 并且

class Courses {
    /**
     *
     * @ORM\OneToMany(targetEntity="NC\InstitutesBundle\Entity\InstitutesCourses", mappedBy="course", cascade={"all"}, orphanRemoval=true)
     */
    protected $instituteCourses;

    /**
     * @return mixed
     */
    public function getInstituteCourses()
    {
        return $this->instituteCourses;
    }

    /**
     * @param mixed $instituteCourses
     */
    public function setInstituteCourses($instituteCourses)
    {
        $this->instituteCourses = $instituteCourses;
    }
}

和桥梁实体。

class InstitutesCourses {

/**
     * @ORM\ManyToOne(targetEntity="PNC\InstitutesBundle\Entity\Institutes", inversedBy="instituteCourses")
     * @ORM\JoinColumn(name="institute_id", referencedColumnName="id")
     */
    protected $institute;
    /**
     * @ORM\ManyToOne(targetEntity="PNC\CoursesBundle\Entity\Courses", inversedBy="instituteCourses")
     * @ORM\JoinColumn(name="course_id", referencedColumnName="id")
     */
    protected $course;
 /**
     * @return mixed
     */
    public function getInstitute()
    {
        return $this->institute;
    }

    /**
     * @param mixed $institute
     */
    public function setInstitute($institute)
    {
        $this->institute = $institute;
    }

    /**
     * @return mixed
     */
    public function getCourse()
    {
        return $this->course;
    }
    /**
     * @param mixed $course
     */
    public function setCourse( $course)
    {
        $this->course = $course;
    }

}

我做了一种机构类型,

->add('courses' , 'entity' , array(
'class'    => 'PNCCoursesBundle:Courses' ,
'property' => 'courseTitle' ,
//'expanded' => true ,
'multiple' => true ,
'attr'=> array(
      'class' => 'form-control',
),
'label_attr' => array(
'class' => 'control-label'
),
)

现在,当我去创建一个新的时它完全保存了记录,当我更新它所说的相同记录时。

  

尝试调用名为" getCourses"的未定义方法。班级   " NC \ InstitutesBundle \实体\ InstitutesCourses&#34 ;.你的意思是打电话吗?   例如" getCourse"或" setCourse"?

1 个答案:

答案 0 :(得分:1)

你尝试混合两种不同的方法。 第一:在学院和课程之间建立多对多的关系。为学院实体创建表格,其中课程是收集。在该方法中,学说在InstitutesCourses表中为每个课程创建记录。 第二:您为InstitutesCourses Entity创建表单。一种形式 - 一个实体。在这种情况下,您必须使用其中一种解决方案。其中之一: 1.在表单类型中,将'courses'设为未映射的字段('mapped'= false) 2.提交表格后,在控制器中获取“课程”数组

$courses=$form->get('courses')->getData();
  1. 为课程中的每门课程制作循环,并手动创建学院课程:

    foreach($ course as $ course){    $ institutesCourse = new InstitutesCourses();    $ institutesCourse-> setCourse($课程)         - > setInstitutes($研究所);    $ EM-> $坚持($ institutesCourse); } $ EM->冲洗();