我没有找到关于如何做到这一点的任何可靠的例子。
我有我的实体Shield,它可以有超过1个ShieldTypes。我想要做的是,创建一个创建一个具有不同Shieldtypes的新盾牌的表单。
这是我的代码,老实说,我不知道我的错误在哪里:
错误是:
Entities passed to the choice field must be managed
500 Internal Server Error - FormException
兵工厂\ 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;
}
}
兵工厂\ 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');
}
}
兵工厂\ 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;
}
}
这可能有点令人困惑,但是:
Shield entity (database)
ShieldTypes entity (database)
ShieldType form (abstracttype)
谢谢...
答案 0 :(得分:4)
所以问题是我没有创建存储库。我创建了它(参见最后的代码),我仍然得到'传递给选择字段的实体必须被管理'错误。
然后我将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
)
);
我希望有人觉得这很有用,因为如果我有这个,那会更容易。
我的存储库代码:
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();
}
}