首頁 > 後端開發 > php教程 > 如何使用 Doctrine 2 的連結表處理帶有額外欄位的多對多關係?

如何使用 Doctrine 2 的連結表處理帶有額外欄位的多對多關係?

DDD
發布: 2024-10-25 01:53:02
原創
254 人瀏覽過

How to Handle Many-to-Many Relationships with Extra Fields Using Doctrine 2's Link Table?

Doctrine 2 和帶有額外欄位的多對多連結表

嘗試使用多對多關係需要連結表中的附加欄位。具體來說,需要一個庫存表。

為了解決這個問題,重要的是要理解這樣的關聯並不是嚴格意義上的多對多關係,而是一個新的實體,因為它現在擁有一個標識符(與連接實體的關係)和附加價值。

數據庫模型應重構如下:

產品:

namespace Entity;

use Doctrine\ORM\Mapping as ORM;

/** @ORM\Table(name="product") @ORM\Entity() */
class Product
{
    /** @ORM\Id() @ORM\Column(type="integer") */
    protected $id;

    /** ORM\Column(name="product_name", type="string", length=50, nullable=false) */
    protected $name;

    /** @ORM\OneToMany(targetEntity="Entity\Stock", mappedBy="product") */
    protected $stockProducts;
}
登入後複製

商店:

namespace Entity;

use Doctrine\ORM\Mapping as ORM;

/** @ORM\Table(name="store") @ORM\Entity() */
class Store
{
    /** @ORM\Id() @ORM\Column(type="integer") */
    protected $id;

    /** ORM\Column(name="store_name", type="string", length=50, nullable=false) */
    protected $name;

    /** @ORM\OneToMany(targetEntity="Entity\Stock", mappedBy="store") */
    protected $stockProducts;
}
登入後複製

庫存:

namespace Entity;

use Doctrine\ORM\Mapping as ORM;

/** @ORM\Table(name="stock") @ORM\Entity() */
class Stock
{
    /** ORM\Column(type="integer") */
    protected $amount;

    /** 
     * @ORM\Id()
     * @ORM\ManyToOne(targetEntity="Entity\Store", inversedBy="stockProducts") 
     * @ORM\JoinColumn(name="store_id", referencedColumnName="id", nullable=false) 
     */
    protected $store;

    /** 
     * @ORM\Id()
     * @ORM\ManyToOne(targetEntity="Entity\Product", inversedBy="stockProducts") 
     * @ORM\JoinColumn(name="product_id", referencedColumnName="id", nullable=false) 
     */
    protected $product;
}
登入後複製

以上是如何使用 Doctrine 2 的連結表處理帶有額外欄位的多對多關係?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板