【问题标题】:Doctrine entity mapping incorrect教义实体映射不正确
【发布时间】:2016-02-28 16:43:20
【问题描述】:

我刚刚创建了一个名为 ProductReviews 的新实体,其中包含以下两个连接。

/**
 * @var \Application\Entity\Products
 *
 * @ORM\ManyToOne(targetEntity="Application\Entity\Products", inversedBy="reviews")
 * @ORM\JoinColumns({
 *   @ORM\JoinColumn(name="product_id", referencedColumnName="product_id")
 * })
 */
private $product;

/**
 * @var \Application\Entity\Users
 *
 * @ORM\ManyToOne(targetEntity="Application\Entity\Users", inversedBy="reviews")
 * @ORM\JoinColumns({
 *   @ORM\JoinColumn(name="user_id", referencedColumnName="user_id")
 * })
 */
private $user;

在我的 Products 实体中

/**
 * @var \Doctrine\ORM\PersistentCollection
 *
 * @ORM\OneToMany(targetEntity="Application\Entity\ProductReviews", cascade={"persist"}, mappedBy="product")
 */
private $reviews;

最后在我的用户实体中

/**
 * @var \Doctrine\ORM\PersistentCollection
 *
 * @ORM\OneToMany(targetEntity="Application\Entity\ProductReviews", mappedBy="user")
 * })
 */
private $reviews;

当我去验证我的实体时,我收到以下错误

[映射] FAIL - 实体类“Application\Entity\ProductReviews”映射无效:

  • 关联 Application\Entity\ProductReviews#product 指的是不存在的反边字段 Application\Entity\Products#reviews。

  • 关联Application\Entity\ProductReviews#user指的是不存在的反边字段Application\Entity\Users#reviews。

但是,两个反向字段都存在,据我所知,映射正确。

谁能发现我做错了什么?

非常感谢。

【问题讨论】:

    标签: orm doctrine-orm zend-framework2


    【解决方案1】:

    我已经想通了。问题是由 Doctrine 缓存引起的,通过清除它,实体现在可以正确映射。

    我使用以下命令行命令清除缓存。

    php ./vendor/doctrine/doctrine-module/bin/doctrine-module orm:clear-cache:query
    php ./vendor/doctrine/doctrine-module/bin/doctrine-module orm:clear-cache:metadata
    php ./vendor/doctrine/doctrine-module/bin/doctrine-module orm:clear-cache:result
    

    以及以下检查实体映射。

    php ./vendor/doctrine/doctrine-module/bin/doctrine-module orm:validate-schema
    

    我希望这对某人有所帮助。

    【讨论】:

      猜你喜欢
      • 2020-03-21
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多