【问题标题】:Symfony2 many-to-many checkboxesSymfony2 多对多复选框
【发布时间】:2015-11-04 16:29:23
【问题描述】:

我知道这个问题回答了很多次,但我不明白我的问题在哪里。 所以我有简单的多对多关系:

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实体:

/**
 * 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 关系表为空。

第二次出现此页面错误:

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:在项目实体中存储设置器

   /**
     * 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;
    }

【问题讨论】:

  • 你能在你的 Item 实体中发布你的 stores setter 吗?
  • 尝试不使用“JoinTable”部分
  • @Marcel Burkhard 难以置信,但它确实有效!我真的很高兴)非常感谢!你能解释一下我的解决方案有什么问题吗?
  • @Asgu 我添加了我的评论作为答案,并解释了为什么它现在可以工作。不幸的是,我对注释映射不够熟悉,无法告诉你哪里出错了。

标签: php symfony checkbox doctrine


【解决方案1】:

从您的 Item 实体中删除 @ORM\JoinTable,如下所示:

class Item
{
    //..
    /**
     * @ORM\ManyToMany(targetEntity="Store", inversedBy="items", cascade="persist"})
     */
    private $stores;
}

Doctrine 为连接表提供了合理的默认值,您可以用一些不起作用的东西覆盖这些默认值。通过删除 @ORM\JoinTable 它应该可以再次工作。

很遗憾,我从不使用注释映射,也无法告诉您错误的确切位置。

如果您需要非默认表名或列名,以下是如何使用@ORM\JoinTablehttp://doctrine-orm.readthedocs.org/en/latest/reference/association-mapping.html#many-to-many-self-referencing

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2015-12-22
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-07-24
    • 1970-01-01
    • 1970-01-01
    • 2014-12-15
    相关资源
    最近更新 更多