我的实体之间存在以下关系。
Institute
之间的一对多 - > InstituteCourses
。 Courses
- >之间的一对多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"?
答案 0 :(得分:1)
你尝试混合两种不同的方法。 第一:在学院和课程之间建立多对多的关系。为学院实体创建表格,其中课程是收集。在该方法中,学说在InstitutesCourses表中为每个课程创建记录。 第二:您为InstitutesCourses Entity创建表单。一种形式 - 一个实体。在这种情况下,您必须使用其中一种解决方案。其中之一: 1.在表单类型中,将'courses'设为未映射的字段('mapped'= false) 2.提交表格后,在控制器中获取“课程”数组
$courses=$form->get('courses')->getData();
为课程中的每门课程制作循环,并手动创建学院课程:
foreach($ course as $ course){ $ institutesCourse = new InstitutesCourses(); $ institutesCourse-> setCourse($课程) - > setInstitutes($研究所); $ EM-> $坚持($ institutesCourse); } $ EM->冲洗();