3

我是 Symfony 2 的新手,我正在尝试为具有外键的内容类型构建一个表单。我不知道如何使用表单保存外键。

我的两个表是“类别”和“问题”。一个问题属于一个类别(多对一)。所以我在实体中的 Question.php 文件包含:

<?php

namespace Iel\CategorieBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
 * Question
 *
 * @ORM\Table()
 * @ORM\Entity(repositoryClass="Iel\CategorieBundle\Entity\QuestionRepository")
 */
class Question
{
    /**
    * @ORM\ManyToOne(targetEntity="Iel\CategorieBundle\Entity\Categorie")
    * @ORM\JoinColumn(nullable=false)
    */
    private $categorie;
    /**
    * Set categorie
    *
    @param Iel\CategorieBundle\Entity\Categorie $categorie
    */
    public function setCategorie(\Iel\CategorieBundle\Entity\Categorie $categorie)
    {
        $this->categorie = $categorie;
    }
    /**
    * Get categorie
    *
    @return Iel\CategorieBundle\Entity\Categorie
    */
    public function getCategorie()
    {
        return $this->categorie;
    }

我尝试过像这样构建控制器功能,但这不是正确的语法:

public function addquestionAction()
{
    $question = new Question;

    $form = $this->createFormBuilder($question)
        ->add('titre', 'text')
        ->add('auteur', 'text')
        ->add('contenu', 'textarea')
        ->add('category_id', $this->getCategorie())    
        ->getForm();    

    $request = $this->get('request');

我不知道如何使用这种形式在问题表中写入当前的 category_id。

4

2 回答 2

8

更好的方法是声明“实体”类型的“类别”。像这样的东西:

$form = $this->createFormBuilder($question)
    ->add('titre', 'text')
    ->add('auteur', 'text')
    ->add('contenu', 'textarea')
    ->add('category', 'entity', array(
        'class' => 'IelCategorieBundle:Categorie',
        'property' => 'name',
    ))
    ->getForm();

这应该创建一个选择,其中选项值是类别 ID,选项显示值是类别名称。持久化 $question 对象将在“questions”表的外键字段中插入类别 ID。

于 2014-03-22T17:49:20.847 回答
2

尝试categorie代替category_id. Doctrine 和 SF2 Forms 使用关联,而不是外键。

$this->getCategorie()也不行。您在控制器上下文中。取而代之的是让表单根据Question映射文件猜测类型。

/* ... */
$form = $this->createFormBuilder($question)
    ->add('titre', 'text')
    ->add('auteur', 'text')
    ->add('contenu', 'textarea')
    ->add('categorie', null)    
    ->getForm(); 
/* ... */
于 2013-10-31T15:32:42.853 回答