Heim > Backend-Entwicklung > PHP-Tutorial > 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
Freigeben: 2024-10-24 18:36:02
Original
412 Leute haben es durchsucht

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
Nach dem Login kopieren

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;
Nach dem Login kopieren

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!

Quelle:php
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage