Doktrin2: Bagaimana Saya Melaksanakan Pada Delete Cascade untuk penyelenggaraan pangkalan data yang lancar?

Mary-Kate Olsen
Lepaskan: 2024-11-03 18:16:03
asal
746 orang telah melayarinya

Doctrine2: How Do I Implement On Delete Cascade for seamless database maintenance?

Doktrin2: Memahami Pada Lata Padam

Untuk penyelenggaraan pangkalan data yang lancar, selalunya perlu memadamkan rekod anak secara automatik apabila rekod induk yang sepadan dipadamkan . Doctrine2 menyokong fungsi ini melalui "On Delete Cascade", satu ciri yang memastikan rekod anak dialih keluar apabila ibu bapa mereka dialih keluar.

Contoh Entiti

Pertimbangkan entiti berikut:

<code class="php">class Child {
    /** @ORM\ManyToOne(targetEntity="Father", cascade={"remove"}) */
    private $father;
}

class Father {
    /** @ORM\Id @ORM\GeneratedValue */
    private $id;
}</code>
Salin selepas log masuk

Penyelesaian: Lata Tahap Pangkalan Data

Untuk melaksanakan benar Pada Lata Pada Padam, tambahkan onDelete="CASCADE" pada lajur gabungan kanak-kanak:

Ini menentukan bahawa apabila satu baris dipadamkan daripada jadual Bapa, semua baris yang sepadan dalam jadual Anak akan dipadamkan secara automatik.

Awas: Fahami Lata

<code class="php">/** @ORM\JoinColumn(name="father_id", referencedColumnName="id", onDelete="CASCADE") */</code>
Salin selepas log masuk
Adalah penting untuk mengambil perhatian perbezaan antara lata peringkat ORM dan peringkat pangkalan data. Lata peringkat ORM beroperasi dalam UnitOfWork Doctrine dan tidak menjejaskan struktur pangkalan data, manakala lata peringkat pangkalan data mencipta kekangan fizikal dalam pangkalan data. Dalam contoh semasa, lata={"remove"} ialah lata peringkat ORM yang akan mencetuskan pemadaman rekursif dalam UnitOfWork, tetapi ia tidak akan menghasilkan gelagat pangkalan data yang diingini.

Atas ialah kandungan terperinci Doktrin2: Bagaimana Saya Melaksanakan Pada Delete Cascade untuk penyelenggaraan pangkalan data yang lancar?. 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
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!