Symfony2 Doctrine ManyToMany不会持续存在

时间:2012-11-27 07:53:02

标签: symfony orm doctrine-orm many-to-many relation

嘿伙计们,我正在寻求帮助。

我的问题是没有存储两个相关的ORM实体。

我运行以下单元测试但失败了:

public function testCategoryRelation()
{
    $doctrine = $this->client->getContainer()->get('doctrine');
    $itemRepo = $doctrine->getRepository("AppBundle:Item");
    $item = $itemRepo->find(230045);
    $this->assertTrue($item instanceof \Acme\TestBundle\Entity\Item);

    $categories = $item->getCategories();
    $this->assertGreaterThan(0, $categories->count());
    foreach ($categories as $category) {
        $this->assertTrue($category instanceof \Acme\TestBundle\Entity\Category);
    }

    $count = $categories->count();
    $categoryRepo = $doctrine->getRepository("AppBundle:Category");
    $categories = $categoryRepo->findBy(array(), null, 2);
    $this->assertEquals( 2, count($categories) );

    foreach ($categories as $category) {
        $this->assertTrue($category instanceof \Acme\TestBundle\Entity\Category);
        $category->addItem($item);
        $item->addCategory($category);
    }
    $this->assertGreaterThan($count, $item->getCategories()->count());

    $em = $doctrine->getManager();
    foreach ($categories as $category) {

        $em->persist($category);
    }
    $em->persist($item);
    $em->flush();
    $em->clear($item);

    $item = $itemRepo->find(230045);
    $categories = $item->getRelatedItems();
    $this->assertGreaterThan($count, $categories->count()); /* Here it fails */
}

我不知道上次测试失败的原因。你能帮我找到我的错误吗?

我与Doctrine 2.3一起运行Symfony 2.1.4

我有两个ORM对象。

1。项目

namespace Acme\TestBundle\Entity;
use Doctrine\ORM\Mapping as ORM;

/**
 * @ORM\Table(name="item")
 */
class Item
{

  /**
   * @ORM\ManyToMany(targetEntity="Category", mappedBy="items")
   */
  private $categories;

  public function __construct()
  {
      $this->categories = new \Doctrine\Common\Collections\ArrayCollection();
  }

  /**
   * @param \Acme\TestBundle\Entity\Category $category
   */
  public function addCategory(\Acme\TestBundle\Entity\Category $category)
  {
      $this->categories[] = $category;
      return $this;
  }

  /**
   * @return \Doctrine\Common\Collections\Collection
   */
  public function getCategories()
  {
      return $this->categories;
  }
}

2。分类

namespace Acme\TestBundle\Entity;
use Doctrine\ORM\Mapping as ORM;

/**
 * @ORM\Table(name="category")
 * @ORM\Entity(repositoryClass="Acme\TestBundle\Repository\CategoryRepository")
 */
class Category
{
  /**
   * @var \Doctrine\Common\Collections\ArrayCollection
   *
   * @ORM\ManyToMany(targetEntity="Item", inversedBy="categories")
   * @ORM\JoinTable(name="category_item",
   *   joinColumns={
   *     @ORM\JoinColumn(name="cat_id", referencedColumnName="id")
   *   },
   *   inverseJoinColumns={
   *     @ORM\JoinColumn(name="item_id", referencedColumnName="id")
   *   }
   * )
   */
  private $items;

  /**
   * @param \Acme\TestBundle\Entity\Item $item
   * @return Category
   */
  public function addItem(\Acme\TestBundle\Entity\Item $item)
  {
      $this->items[] = $item;
      return $this;
  }

  /**
   * @return \Doctrine\Common\Collections\Collection
   */
  public function getItems()
  {
      return $this->items;
  }
}

提前感谢您的帮助!

1 个答案:

答案 0 :(得分:0)

嗯,$categories = $item->getRelatedItems();。也许最好写$categories = $item->getCategories();

另一个建议是将__construct方法添加到Category实体类并使用new ArrayCollection初始化$ items