Rumah > pangkalan data > tutorial mysql > Bagaimana Mengendalikan Hubungan Banyak-ke-Banyak dengan Medan Tambahan dalam Doktrin 2?

Bagaimana Mengendalikan Hubungan Banyak-ke-Banyak dengan Medan Tambahan dalam Doktrin 2?

Patricia Arquette
Lepaskan: 2024-12-22 01:55:11
asal
772 orang telah melayarinya

How to Handle Many-to-Many Relationships with Extra Fields in Doctrine 2?

Doktrin 2 dan Jadual Pautan Many-to-many dengan Medan Tambahan: Dijelaskan

Menjelaskan Pertanyaan

Dalam soalan asal, pengguna mendapatkan panduan untuk mencipta perhubungan banyak-ke-banyak dalam jadual pautan yang mengandungi medan tambahan (jumlah stok). Cabaran timbul apabila mengakses nilai jumlah stok menggunakan Doktrin dan menjana struktur jadual pangkalan data.

Menangani Isu

Isu ini berpunca daripada andaian bahawa ramai-kepada -banyak hubungan dengan nilai tambahan boleh dianggap sedemikian. Walau bagaimanapun, perhubungan banyak-ke-banyak dengan nilai tambahan menjadi entiti baharu dengan pengecam dan nilai.

Penyelesaian

Penyelesaian melibatkan mewujudkan entiti berasingan yang dipanggil Saham dengan lajur berikut:

  • Amaun (untuk menyimpan stok value)
  • Hubungan kepada entiti Produk dan Kedai

Ini membenarkan sistem memodelkan perhubungan banyak-ke-banyak dengan tepat, memberikan akses kepada nilai jumlah stok menggunakan Doktrin.

Entiti Kemas Kini

Di bawah ialah entiti yang diselaraskan definisi:

Produk:

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;
}
Salin selepas log masuk

Kedai:

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;
}
Salin selepas log masuk

Stok:

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;
}
Salin selepas log masuk

Pangkalan data Struktur

Perubahan ini menghasilkan struktur pangkalan data yang ditunjukkan di bawah:

CREATE TABLE product (
  id INT NOT NULL,
  product_name VARCHAR(50) NOT NULL,
  PRIMARY KEY (id)
);

CREATE TABLE store (
  id INT NOT NULL,
  store_name VARCHAR(50) NOT NULL,
  PRIMARY KEY (id)
);

CREATE TABLE stock (
  amount INT NOT NULL,
  store_id INT NOT NULL,
  product_id INT NOT NULL,
  PRIMARY KEY (store_id, product_id),
  FOREIGN KEY (store_id) REFERENCES store (id),
  FOREIGN KEY (product_id) REFERENCES product (id)
);
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimana Mengendalikan Hubungan Banyak-ke-Banyak dengan Medan Tambahan dalam Doktrin 2?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan