4

我有两个名为 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))
            [...]
        ;
    }
}
4

0 回答 0