Symfony2 多对多复选框
Symfony2 many-to-many checkboxes
我知道这个问题已经回答了很多次,但我不明白我的问题在哪里。
所以我有简单的多对多关系:
class Item
{
/**
* @var integer
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @ORM\ManyToMany(targetEntity="Store", inversedBy="items", cascade={"persist"})
* @ORM\JoinTable(name="itemlist",
* joinColumns={@ORM\JoinColumn(name="item", referencedColumnName="id")},
* inverseJoinColumns={@ORM\JoinColumn(name="store", referencedColumnName="id")}
* )
*/
private $stores;
}
和商店实体:
/**
* Store
*
* @ORM\Table()
* @ORM\Entity
*/
class Store
{
/**
* @var integer
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @ORM\ManyToMany(targetEntity="Item", mappedBy="stores", cascade={"persist"})
*/
private $items;
}
我想通过复选框将商品分配给商店。
所以生成ItemType:
class ItemType extends AbstractType
{
/**
* @param FormBuilderInterface $builder
* @param array $options
*/
public function buildForm(FormBuilderInterface $builder, array $options)
{
$entityManager = $options['em'];
$builder
//...
->add('stores', 'entity', array('class' => 'FoodBundle:Store', 'property' => 'title','multiple' => true, 'expanded' => true))
;
}
问题从这里开始。
首先我选中了所有复选框,但是 itemlist
关系 table 是空的。
其次我在这个页面中遇到错误:
Notice: Undefined index: targetToSourceKeyColumns in \vendor\doctrine\orm\lib\Doctrine\ORM\Persisters\Entity\BasicEntityPersister.php on line 1773
Warning: Invalid argument supplied for foreach() \vendor\doctrine\orm\lib\Doctrine\ORM\Persisters\Entity\BasicEntityPersister.php on line 1773
最后我无法通过复选框和获取来管理关系:
Uncaught PHP Exception Symfony\Component\Debug\Exception\ContextErrorException: "Catchable Fatal Error: Argument 1 passed to Doctrine\Common\Collections\ArrayCollection::__construct() must be of the type array, object given, called in C:\Program Files (x86)\EasyPHP-DevServer-14.1VC11\data\localweb\foodserv\vendor\doctrine\orm\lib\Doctrine\ORM\UnitOfWork.php on line 605 and defined
我认为映射有问题,但是这个解决方案完全复制自 symfony2 many-to-many form checkbox
UPD:在 Item 实体中存储 setter
/**
* Add store
*
* @param \FoodServiceBundle\Entity\Store $store
*
* @return Item
*/
public function addStore(\FoodServiceBundle\Entity\Store $store)
{
$this->stores[] = $store;
return $this;
}
/**
* Remove store
*
* @param \FoodServiceBundle\Entity\Store $store
*/
public function removeStore(\FoodServiceBundle\Entity\Store $store)
{
$this->stores->removeElement($store);
}
/**
* Get stores
*
* @return \Doctrine\Common\Collections\Collection
*/
public function getStores()
{
return $this->stores;
}
从您的项目实体中删除 @ORM\JoinTable
,如下所示:
class Item
{
//..
/**
* @ORM\ManyToMany(targetEntity="Store", inversedBy="items", cascade="persist"})
*/
private $stores;
}
Doctrine 为连接 table 提供了合理的默认值,您可以用无效的东西覆盖它们。通过删除 @ORM\JoinTable
它应该再次工作。
不幸的是,我从来没有使用过注释映射,也无法告诉您错误的确切位置。
如果您需要非默认 table 或列名称,请使用 @ORM\JoinTable
:http://doctrine-orm.readthedocs.org/en/latest/reference/association-mapping.html#many-to-many-self-referencing
我知道这个问题已经回答了很多次,但我不明白我的问题在哪里。 所以我有简单的多对多关系:
class Item
{
/**
* @var integer
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @ORM\ManyToMany(targetEntity="Store", inversedBy="items", cascade={"persist"})
* @ORM\JoinTable(name="itemlist",
* joinColumns={@ORM\JoinColumn(name="item", referencedColumnName="id")},
* inverseJoinColumns={@ORM\JoinColumn(name="store", referencedColumnName="id")}
* )
*/
private $stores;
}
和商店实体:
/**
* Store
*
* @ORM\Table()
* @ORM\Entity
*/
class Store
{
/**
* @var integer
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @ORM\ManyToMany(targetEntity="Item", mappedBy="stores", cascade={"persist"})
*/
private $items;
}
我想通过复选框将商品分配给商店。
所以生成ItemType:
class ItemType extends AbstractType
{
/**
* @param FormBuilderInterface $builder
* @param array $options
*/
public function buildForm(FormBuilderInterface $builder, array $options)
{
$entityManager = $options['em'];
$builder
//...
->add('stores', 'entity', array('class' => 'FoodBundle:Store', 'property' => 'title','multiple' => true, 'expanded' => true))
;
}
问题从这里开始。
首先我选中了所有复选框,但是 itemlist
关系 table 是空的。
其次我在这个页面中遇到错误:
Notice: Undefined index: targetToSourceKeyColumns in \vendor\doctrine\orm\lib\Doctrine\ORM\Persisters\Entity\BasicEntityPersister.php on line 1773
Warning: Invalid argument supplied for foreach() \vendor\doctrine\orm\lib\Doctrine\ORM\Persisters\Entity\BasicEntityPersister.php on line 1773
最后我无法通过复选框和获取来管理关系:
Uncaught PHP Exception Symfony\Component\Debug\Exception\ContextErrorException: "Catchable Fatal Error: Argument 1 passed to Doctrine\Common\Collections\ArrayCollection::__construct() must be of the type array, object given, called in C:\Program Files (x86)\EasyPHP-DevServer-14.1VC11\data\localweb\foodserv\vendor\doctrine\orm\lib\Doctrine\ORM\UnitOfWork.php on line 605 and defined
我认为映射有问题,但是这个解决方案完全复制自 symfony2 many-to-many form checkbox
UPD:在 Item 实体中存储 setter
/**
* Add store
*
* @param \FoodServiceBundle\Entity\Store $store
*
* @return Item
*/
public function addStore(\FoodServiceBundle\Entity\Store $store)
{
$this->stores[] = $store;
return $this;
}
/**
* Remove store
*
* @param \FoodServiceBundle\Entity\Store $store
*/
public function removeStore(\FoodServiceBundle\Entity\Store $store)
{
$this->stores->removeElement($store);
}
/**
* Get stores
*
* @return \Doctrine\Common\Collections\Collection
*/
public function getStores()
{
return $this->stores;
}
从您的项目实体中删除 @ORM\JoinTable
,如下所示:
class Item
{
//..
/**
* @ORM\ManyToMany(targetEntity="Store", inversedBy="items", cascade="persist"})
*/
private $stores;
}
Doctrine 为连接 table 提供了合理的默认值,您可以用无效的东西覆盖它们。通过删除 @ORM\JoinTable
它应该再次工作。
不幸的是,我从来没有使用过注释映射,也无法告诉您错误的确切位置。
如果您需要非默认 table 或列名称,请使用 @ORM\JoinTable
:http://doctrine-orm.readthedocs.org/en/latest/reference/association-mapping.html#many-to-many-self-referencing