简体   繁体   English

symfony2实体字段类型错误

[英]symfony2 entity field type error

I haven't found any solid example on how to do this. 我还没有找到有关如何执行此操作的可靠示例。

I have my entity Shield, which can have more than 1 ShieldTypes. 我有我的实体Shield,它可以具有多个ShieldType。 What I want to do is, create a form that creates a new Shield with different Shieldtypes. 我想做的是,创建一个表单,该表单创建具有不同Shieldtypes的新Shield。

This is my code, I honestly don't know where is my error: 这是我的代码,老实说我不知道​​我的错误在哪里:

Error is: 错误是:

Entities passed to the choice field must be managed
500 Internal Server Error - FormException 

Armory\\SearchBundle\\Entity\\Shield.php 军械库\\ SearchBundle \\实体\\ Shield.php

namespace Armory\SearchBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
/**
 * Armory\SearchBundle\Entity\Shield
 *
 * @ORM\Table(name="shield")
 * @ORM\Entity
 */
class Shield
{
    /**
     * @var integer $id
     * @ORM\Column(name="id", type="integer", nullable=false)
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="IDENTITY")
     */
    private $id;
    /**
     * @var string $name
     * @ORM\Column(name="name", type="string", length=45, nullable=false)
     */
    private $name;
    /**
     * @var integer $defense
     * @ORM\Column(name="defense", type="integer", nullable=false)
     */
    private $defense;

    /**
     * @var boolean $active
     * @ORM\Column(name="active", type="boolean", nullable=false)
     */
    private $active;

    /**
     * @ORM\ManyToMany(targetEntity="ShieldTypes")
     * @ORM\JoinTable(name="i_orbs_type",
     *     joinColumns={@ORM\JoinColumn(name="id_orb", referencedColumnName="id")},
     *     inverseJoinColumns={@ORM\JoinColumn(name="id_type", referencedColumnName="id")}
     * )
     * @var ArrayCollection $types
     */
    protected $types;
    public function __construct(){
        $this->types = new \Doctrine\Common\Collections\ArrayCollection();
    }
    public function getTypes(){
        return $this->types;
    }
    public function getId()
    {
        return $this->id;
    }
    public function setName($name)
    {
        $this->name = $name;
    }
    public function getName()
    {
        return $this->name;
    }
    public function setDefense($defense)
    {
        $this->defense = $defense;
    }
    public function getDefense()
    {
        return $this->defense;
    }
    public function setActive($active)
    {
        $this->active = $active;
    }
    public function getActive()
    {
        return (bool)$this->active;
    }
}

Armory\\SearchBundle\\Form\\ShieldType.php: 军械库\\ SearchBundle \\表格\\ ShieldType.php:

namespace Armory\SearchBundle\Form;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilder;
class ShieldType extends AbstractType{

public function buildForm(FormBuilder $builder, array $options){
    $builder->add('name','text');
    $builder->add('defense','integer');
    $builder->add('active','checkbox');

    $builder->add('types','entity',
            array(
                'class'=>'Armory\SearchBundle\Entity\ShieldTypes', 
                'query_builder'=> function($repository){ 
                            return $repository->createQueryBuilder('t')->orderBy('t.id', 'ASC');
                    },
                'property'=>'name', )
            );
}

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

public function getDefaultOptions(array $options){
    return array('data_class'=>'Armory\\SearchBundle\\Entity\\Shield');
}
}

Armory\\SearchBundle\\Entity\\ShieldTypes.php 军械库\\ SearchBundle \\实体\\ ShieldTypes.php

namespace Armory\SearchBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
/**
 * SOA\CRMBundle\Entity\ShieldTypes
 *
 * @ORM\Table(name="orbs_type")
 * @ORM\Entity
 */
class ShieldTypes
{
    /**
     * @var integer $id
     *
     * @ORM\Column(name="id", type="integer", nullable=false)
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="IDENTITY")
     */
    private $id;
    /**
     * @var string $name
     *
     * @ORM\Column(name="name", type="string", length=45, nullable=false)
     */
    private $name;
    /**
     * @var string $title
     *
     * @ORM\Column(name="title", type="string", length=45, nullable=false)
     */
    private $title;
    public function getId()
    {
        return $this->id;
    }
    public function setName($name)
    {
        $this->name = $name;
    }
    public function getName()
    {
        return $this->name;
    }
    public function setTitle($title)
    {
        $this->title = $title;
    }
    public function getTitle()
    {
        return $this->title;
    }   
}

It can be a little confusing but: 可能会有些混乱,但是:

Shield entity (database)
ShieldTypes entity (database)
ShieldType form (abstracttype)

Thank you... 谢谢...

So the problem was that I didn't create a repository. 所以问题是我没有创建存储库。 I created it (see code at the end) and I still got 'Entities passed to the choice field must be managed' error. 我创建了它(请参阅最后的代码),但仍然收到“必须将传递给选择字段的实体进行管理”错误。

Then I set mutiple to true in: 然后在以下方式将mutiple设置为true:

$builder->add('types','entity',
                array(
                    'class'=>'Armory\SearchBundle\Entity\ShieldTypes', 
                    'query_builder'=> function(\Armory\SearchBundle\Entity\Repository\ShieldTypesRepository $repository){ 
                                    return $repository->createQueryBuilder('s')->orderBy('s.id', 'ASC');},
                    'property'=>'title', 
                    'multiple'=>true
                    )
                );

I hope someone finds this useful, cause if I had had this, it would been easier. 我希望有人觉得这个有用,因为如果我有这个,那会容易些。

Code for my repository: 我的存储库的代码:

namespace Armory\SearchBundle\Entity\Repository;
use Doctrine\ORM\EntityRepository;

class ShieldTypesRepository extends EntityRepository
{
    public function getAll()
    {
        return $this->_em->createQuery('SELECT s FROM Armory\SearchBundle\Entity\ShieldTypes s')
                         ->getResult();
    }
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM