我有两个名为 Question 和 SolutionMethod 的 PHP 模型类。一个类别可能有许多项目,一个项目可能属于许多类别。我已经为这两个类创建了 ManyToMany 关系:
class Question {
/**
* @ORM\ManyToMany(targetEntity="SolutionMethod", mappedBy="questions", cascade={"persist"})
*/
private $solutions;
/**
* Add items
*
* @param Acme\MyBundle\Entity\SolutionMethod $solution
*/
public function addItems(\Acme\MyBundle\Entity\SolutionMethod $solution) {
$this->solutions[] = $solutions;
}
/**
* Get solutions
*
* @return Doctrine\Common\Collections\Collection
*/
public function getSolutions() {
return $this->solutions;
}
[...]
}
和
class SolutionMethod {
/**
* @ORM\ManyToMany(targetEntity="Question", inversedBy="solutions", cascade={"persist"})
* @ORM\JoinTable(name="question_solution")
*/
private $questions;
/**
* Add questions
*
* @param Acme\MyBundle\Entity\Question $question
*/
public function addCategories(\Acme\MyBundle\Entity\Question $question) {
$this->questions[] = $question;
}
/**
* Get questions
*
* @return Doctrine\Common\Collections\Collection
*/
public function getQuestions() {
return $this->questions;
}
[...]
}
在我的表单中,此关联是使用具有所需属性的多选呈现的,但我有一些没有解决方案方法的问题,但我无法保存,并且出现了所需的消息。
解决了!
解决方案如此简单,让我觉得自己像个白痴
class QuestionType extends AbstractType {
public function buildForm(FormBuilder $builder, array $options) {
$builder
->add('solutions', null, array('required' => false))
[...]
;
}
}