Heim >Backend-Entwicklung >PHP-Tutorial >Wie verwaltet man komplexe Viele-zu-Viele-Beziehungen mit zusätzlichen Feldern in Lehre 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!