1

我正在尝试构建“编辑”控制器/视图,但遇到此错误。从我读到它可能是一个关联问题,我已经尝试修复它,但我不知道它有什么问题。它应该返回一个集合,但我什至不知道“代理”是什么意思以及它是如何得到它的。

我正在为其构建编辑视图的实体:

    <?php

namespace Monse\WebBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
 * Monse\WebBundle\Entity\BasedeDatos
 *
 * @ORM\Table()
 * @ORM\Entity
 */
class BasedeDatos
{
    /**
     * @var integer $id
     *
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    private $id;

   /**
* @ORM\ManyToOne(targetEntity="Monse\WebBundle\Entity\ServidoresBD")
* @ORM\JoinColumn(name="servidores_id", referencedColumnName="id",nullable=false)
*
*/
    private $servidorBD;

    /**
     * @var string $nombreBD
     *
     * @ORM\Column(name="nombreBD", type="string", length=255,unique=true)
     */
    private $nombreBD;


    /**
     * Get id
     *
     * @return integer 
     */
    public function getId()
    {
        return $this->id;
    }

    /**
     * Set servidorBD
     *
     * @param integer $servidorBD
     */
    public function setServidorBD(\Monse\WebBundle\Entity\ServidoresBD $servidorBD)
    {
        $this->servidorBD = $servidorBD;
    }

    /**
     * Get servidorBD
     *
     * @return integer 
     */
    public function getServidorBD()
    {
        return $this->servidorBD;
    }

    /**
     * Set nombreBD
     *
     * @param string $nombreBD
     */
    public function setNombreBD($nombreBD)
    {
        $this->nombreBD = $nombreBD;
    }

    /**
     * Get nombreBD
     *
     * @return string 
     */
    public function getNombreBD()
    {
        return $this->nombreBD;
    }
    public function __construct()
    {
        $this->servidorBD = new Doctrine\Common\Collections\ArrayCollection();
    }
}

表格类型:

<?php

namespace Monse\WebBundle\Form;
use Doctrine\ORM\EntityRepository;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilder;

class BasedeDatosType extends AbstractType
{ 
    public function buildForm(FormBuilder $builder, array $options)
    {
        $builder
           ->add('ServidorBD','entity',
                  array ('class' => 'MonseWebBundle:ServidoresBD',
                        'multiple' => true, 
                        'required' => true, 
                        'label' => 'Servidor de Base de Datos: ',
                         'query_builder' => function(EntityRepository $er) {
                         return $er->createQueryBuilder('u')
                         ->orderBy('u.url', 'ASC');
                                                                           },
                         ))
            ->add('nombreBD','text', array( 'required' => true, 'label' => 'Nombre Base de Datos: '))
            ->add('UsuarioBD','entity',array('class' => 'MonseWebBundle:UsuariosBD','multiple' => true,
                                             'required' => true, 'label' => 'Usuario Asociado: ',
                                             'property_path' => false,
                                             'query_builder' => function (EntityRepository $er){
                                              return $er->createQueryBuilder('s')
                                              ->orderBy ('s.usuario','ASC'); },))
            ;

    }

    public function getName()
    {
        return 'basededatos';
    }
}

负责该问题的实体(我认为):

<?php

namespace Monse\WebBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
 * Monse\WebBundle\Entity\ServidoresBD
 *
 * @ORM\Table()
 * @ORM\Entity
 */
class ServidoresBD
{
    /**
     * @var integer $id
     *
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    private $id;
    /**
     * @var string $url
     *
     * @ORM\Column(name="url", type="string", length=255)
     */
    private $url;
  /**
   *
   * @ORM\OneToOne (targetEntity="Monse\WebBundle\Entity\Dominios")
   * @ORM\JoinColumn(name="dominio_id", referencedColumnName="id",nullable=false,unique=true)
   */
    private $dominio;


    /**
     * Get id
     *
     * @return integer 
     */
    public function getId()
    {
        return $this->id;
    }

    /**
     * Set dominio
     *
     * @param integer $dominio
     */
    public function setDominio(\Monse\WebBundle\Entity\Dominios $dominio)
    {
        $this->dominio = $dominio;
    }

    /**
     * Get dominio
     *
     * @return integer 
     */
    public function getDominio()
    {
        return $this->dominio;
    }

     /**
     * Set url
     *
     * @param string $url
     */
    public function setUrl($url)
    {
        $this->url = $url;
    }

    /**
     * Get url
     *
     * @return string 
     */
    public function getUrl()
    {
        return $this->url;
    }
    public function __toString()
{
    return $this->getUrl();
}

}

表格类型:

<?php

namespace Monse\WebBundle\Form;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilder;

class ServidoresBDType extends AbstractType
{
    public function buildForm(FormBuilder $builder, array $options)
    {
        $builder
            ->add('url')
            ->add('dominio', 'collection', array('type' => new DominiosType()));
        ;
    }
 public function getDefaultOptions(array $options)
    {   
        return array(
            'data_class' => 'Monse\WebBundle\Entity\ServidoresBD'
        );
    }
   public function getName()
{
    return 'issue_selector';
}
}

我应该在哪里添加要返回的arraycollection?我如何防止这种情况再次发生?如果这是一个愚蠢的问题,我很抱歉,我正在努力学习。

4

1 回答 1

0

我在第一个表单类型中将两个“多个”属性更改为 false。

于 2013-01-01T18:31:15.563 回答