Heim  >  Artikel  >  Backend-Entwicklung  >  Wie verwaltet man komplexe Viele-zu-Viele-Beziehungen mit zusätzlichen Feldern in Lehre 2?

Wie verwaltet man komplexe Viele-zu-Viele-Beziehungen mit zusätzlichen Feldern in Lehre 2?

Linda Hamilton
Linda HamiltonOriginal
2024-10-24 18:36:02290Durchsuche

How to Manage Complex Many-to-Many Relationships with Additional Fields in Doctrine 2?

Verwalten von Viele-zu-Viele-Beziehungen mit zusätzlichen Feldern unter Verwendung von Doktrin 2

Bei der Datenbankmodellierung handelt es sich häufig um eine Viele-zu-Viele-Beziehung eine Linktabelle zum Herstellen von Verbindungen zwischen Entitäten. Wenn diesen Verknüpfungstabellen jedoch zusätzliche Werte zugeordnet werden, sind herkömmliche Viele-zu-Viele-Beziehungen unzureichend.

Stellen Sie sich das Szenario vor, in dem ein System den Lagerbestand für Produkte in mehreren Filialen verfolgen muss. Eine grundlegende Viele-zu-Viele-Beziehung könnte mit der folgenden Datenbankstruktur erstellt werden:

Product:
  - product_id
  - product_name

Store:
  - store_id
  - store_name

Stock:
  - amount
  - product_id
  - store_id

Dieser Struktur fehlt jedoch die Möglichkeit, Lagerbestände für jede Kombination von Produkten und Geschäften zu verfolgen. Um dieses Problem zu beheben, kann der Tabelle „Lagerbestand“ ein zusätzliches Feld, z. B. „Betrag“, hinzugefügt werden. Dies führt zu einer neuen Entität und nicht zu einer bloßen Verknüpfungstabelle, da diese nun sowohl Bezeichner als auch Werte besitzt.

In Lehre 2 kann dies mithilfe der folgenden Entitätsdefinitionen implementiert werden:

Product:
  /** @ORM\OneToMany(targetEntity="Entity\Stock", mappedBy="product") */
  protected $stockProducts;

Store:
  /** @ORM\OneToMany(targetEntity="Entity\Stock", mappedBy="store") */
  protected $stockProducts;

Stock:
  /** ORM\Column(type="integer") */
  protected $amount;
  /** @ORM\ManyToOne(targetEntity="Entity\Store", inversedBy="stockProducts") */
  protected $store;
  /** @ORM\ManyToOne(targetEntity="Entity\Product", inversedBy="stockProducts") */
  protected $product;

Durch die Definition einer separaten „Lager“-Entität mit bidirektionalen Beziehungen zu „Produkt“ und „Geschäft“ können wir die mit jeder Kombination aus Produkt und Geschäft verbundenen Lagerbestände effektiv verwalten.

Das obige ist der detaillierte Inhalt vonWie verwaltet man komplexe Viele-zu-Viele-Beziehungen mit zusätzlichen Feldern in Lehre 2?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn