我在实体之间有多对一的关系Project and Course因为每门课程可以有许多项目,所以许多项目可能与同一门课程相关。
这些是我的实体:
class Project{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
//... other fields ...
//----------------------- DATABASE RELATIONSHIP ----------------//
//PROJECT-COURSE - M:1 relationship
/**
* @ORM\ManyToOne(targetEntity="Course", inversedBy="project")
* @ORM\JoinColumn(name="course_id", referencedColumnName="id")
**/
private $course;
and
class Course{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
//... other fields ...
//----------------------- DATABASE RELATIONSHIP----------------//
//COURSE-PROJECT 1:M relationship
/**
* @ORM\OneToMany(targetEntity="Project", mappedBy="course")
**/
private $project;
当我尝试为我的课程插入新项目时出现错误,这是我的表单生成器:
$builder
->add('name', 'text', array(
'attr' => array('class' => 'form-control')))
->add('description', 'textarea', array(
'attr' => array('class' => 'form-control', 'rows' => '10')))
->add('submit', 'submit', array(
'attr' => array('class' => 'btn btn-primary')));
我尝试插入这些数据,创建一个 Project 对象并用表单的结果填充它,如您所见:
$project->setName($form->get('name')->getData());
$project->setDescription($form->get('description')->getData());
$project->setPhasesNumber($form->get('phases_number')->getData());
$project->setPathNumber($form->get('path_number')->getData());
$project->setYear(date('Y'));
$project->setCourse(5); //number 5 is just a test
$em = $this->getDoctrine()->getManager();
$em->persist($project);
$em->flush();
问题应该与命令有关$project->setCourse(5);
我已经看到,如果我删除项目和课程之间的关系,则不会出现错误。即使我注释了用于设置课程 id 的行,该错误也会消失,所以我认为这种关系有问题,但我不明白在哪里。
我刚刚在 stackoverflow 上读到了类似的其他问题,但这对我没有帮助。
提前致谢。