8

另一个问题。我有一个抽象的 BaseLog 实体,它保持与我的用户的关联。此外,我有 2 个扩展 BaseLog 的实体(FooLog 和 BarLog)。此外,我有我的用户实体,假设它持有两个与日志的关联。一个用于 FooLog,一个用于 BarLog。这是我的问题。我收到错误消息,因为我不知道如何在扩展 Entity 时覆盖 BaseLog 的 inversedBy 字段。请你帮助我好吗。

因为我觉得我的解释不太好,这里是我的实体的设置。

基本日志

/** @ORM\MappedSuperclass */
abstract class BaseLog {
  /**
   * @ORM\ManyToOne(targetEntity="User", inversedBy="logs")
   * @ORM\JoinColumns({
   *   @ORM\JoinColumn(name="user_id", referencedColumnName="id", nullable=true, onDelete="SET NULL")
   * })
   */
  private $user;
}

FooLog

/** @ORM\Entity */
class FooLog extends BaseLog {
  // Some additional fields
}

条形记录仪

/** @ORM\Entity */
class BarLog extends BaseLog {
  // Some additional fields
}

用户

/** @ORM\Entity */
class User {
  /**
   * @ORM\OneToMany(targetEntity="FooLog", mappedBy="user", cascade={"persist"})
   */
  private $fooLogs;

  /**
   * @ORM\OneToMany(targetEntity="BarLog", mappedBy="user", cascade={"persist"})
   */
  private $barLogs;
}

如何在FooLogBarLog中覆盖BaseLoginversedBy

我在这个设置上遇到了几个映射错误:BaseLog

  • BaseLog:关联BaseLog#user是指不存在的反边字段User#logs。
  • FooLog:关联 FooLog#user 是指不存在的反边字段 User#logs。
  • BarLog:关联 BarLog#user 是指不存在的反边字段 User#logs。
  • 用户:映射 User#fooLogs 和 FooLog#user 彼此不一致。
  • 用户:映射 User#barLogs 和 BarLog#user 彼此不一致。

请帮我整理我的映射。

4

4 回答 4

4

我对单继承也有类似的问题。我通过在两个实体类(父类和继承类)中定义相同的关联但名称不同来解决这个问题。在你的情况下,你可以试试这个:

    /** @ORM\Entity */
class FooLog extends BaseLog {
  /**
   * @ORM\ManyToOne(targetEntity="User", inversedBy="foologs")
   * @ORM\JoinColumns({
   *   @ORM\JoinColumn(name="user_id", referencedColumnName="id", nullable=true, onDelete="SET NULL")
   * })
   */
   private $user;
}

在 BarLog 类中:

/** @ORM\Entity */
    class BarLog extends BaseLog {
      /**
       * @ORM\ManyToOne(targetEntity="User", inversedBy="barlogs")
       * @ORM\JoinColumns({
       *   @ORM\JoinColumn(name="user_id", referencedColumnName="id", nullable=true, onDelete="SET NULL")
       * })
       */
       private $bar_user;
    }

注意不同的名称($bar_user)。您还必须在用户实体中定义foologs 和barlogs 属性。这消除了学说验证错误。

于 2013-09-26T10:37:21.697 回答
3

我一直在使用Single Table Inheritance解决同样的问题。据我所知,没有解决方案。尽管inversedBy被认为是强制性的,但似乎您可以忽略它而侥幸逃脱。然而,正如 Doctrine 文档所暗示的那样,性能迅速恶化。

@AssociationOverride没有帮助,因为您不能修改关联定义,只能修改数据库列属性。

我尝试了许多选项,但没有一个是令人满意的。

更新:运行时我仍然无法找到解决此类错误的任何方法app/console doctrine:schema:validate

[Mapping]  FAIL - The entity-class 'Acme\AcmeBundle\Entity\CourseLocation' mapping is invalid:
* The field Acme\AcmeBundle\Entity\CourseLocation#facilitators is on the inverse side of a bi-directional relationship, but the specified mappedBy association on the target-entity Acme\AcmeBundle\Entity\CourseFacilitatorResponsibility#courseLocation does not contain the required 'inversedBy' attribute.

在这种情况下CourseFacilitatorResponsibility,是 的子类(具有单表继承)CourseResponsibilityCourseLocation指多个CourseResponsibility实体。我认为单向关联是解决它的唯一方法。

于 2013-03-04T07:11:22.093 回答
1

IIRC 在旧版本的 Doctrine 中没有覆盖映射的好方法。在 Doctrine >= 2.2 中有一种叫做关联覆盖的东西,所以也许你可以使用它。

顺便说一句,为什么您不想将关联从基类移动到具体类并定义有效的 inversedBy 呢?

于 2012-12-12T08:30:09.663 回答
1

执行此操作的正确方法(自 Doctrine 2.3 起)是使用AssociationOverrides.

inversedBy="logs"从类中删除BaseLog——因为映射的超类无论如何都不代表真实的实体——然后在子类中覆盖它。这应该是这样的:

基本日志

/** @ORM\MappedSuperclass */
abstract class BaseLog {
  /**
   * @ORM\ManyToOne(targetEntity="User")
   * @ORM\JoinColumns({
   *   @ORM\JoinColumn(name="user_id", referencedColumnName="id", nullable=true, onDelete="SET NULL")
   * })
   */
  private $user;
}

FooLog

/**
 * @ORM\Entity */
 * @ORM\AssociationOverrides({
 *     @ORM\AssociationOverride(name="user", inversedBy="fooLogs")
 * })
 */
class FooLog extends BaseLog {
  // Some additional fields
}

条形记录仪

/**
 * @ORM\Entity */
 * @ORM\AssociationOverrides({
 *     @ORM\AssociationOverride(name="user", inversedBy="barLogs")
 * })
 */
class BarLog extends BaseLog {
  // Some additional fields
}

name=in@ORM\AssociationOverride表示要从映射的超类中覆盖的字段。

于 2020-04-27T17:48:40.520 回答