简介:
许多一对多关系通常涉及附加字段,这些字段提供特定于每个关系实例的额外信息。然而,在原则 2 中处理此类关系可能有点棘手。本文旨在阐明如何有效地对这些关系进行建模。
问题:
用户尝试创建具有多对多关系的数据库模型,包括一个额外的库存字段。然而,他们在尝试使用 Doctrine 的模式工具访问库存金额值并生成数据库表时遇到了问题。
解决方案:
理解许多- 具有额外字段的多对多关系
具有附加字段的多对多关系本质上本身就是一个新实体,因为它现在具有标识符(与连接实体的关系)和值。因此,将其建模为没有值的链接表是不够的。
为具有额外字段的关系创建单独的实体
建议的方法是创建一个单独的实体,例如本例中的“Stock”,它表示关系并包含额外的字段。该实体与所涉及的两个实体建立关系,每个关系都由“Stock”实体中的外键表示。
代码示例:
这里有一个示例如何在 Doctrine 2 注释中定义实体:
// Product Entity @ORM\OneToMany(targetEntity="Entity\Stock", mappedBy="product") protected $stockProducts; // Store Entity @ORM\OneToMany(targetEntity="Entity\Stock", mappedBy="store") protected $stockProducts; // Stock Entity @ORM\Id() @ORM\ManyToOne(targetEntity="Entity\Store", inversedBy="stockProducts") protected $store; @ORM\Id() @ORM\ManyToOne(targetEntity="Entity\Product", inversedBy="stockProducts") protected $product;
其他注意事项:
以上是如何在原则 2 中使用额外字段建模多对多关系?的详细内容。更多信息请关注PHP中文网其他相关文章!