Bolehkah MySQL Triggers Mengemas kini Jadual Sama Yang Dipanggil Mereka?

Susan Sarandon
Lepaskan: 2024-10-29 04:00:02
asal
554 orang telah melayarinya

 Can MySQL Triggers Update the Same Table They Are Called From?

Pencetus MySQL: Had dengan Mengemas kini Baris Jadual Yang Sama

Soalan: Bagaimana anda menetapkan nilai untuk baris baharu dalam pencetus dan kemas kini MySQL satu lagi baris dalam jadual yang sama?

Percubaan telah dibuat untuk mencipta pencetus yang melakukan operasi berikut semasa sisipan baris:

  1. Kira dan tetapkan nilai khusus untuk baris baharu.
  2. Tetapkan tarikh tamat baris sebelumnya kepada satu hari sebelum tarikh mula baris baharu.

Walau bagaimanapun, pencetus mengakibatkan ralat: "Tidak dapat mengemas kini pemisahan jadual dalam disimpan fungsi/cetusan kerana ia sudah digunakan oleh pernyataan yang menggunakan fungsi/cetusan tersimpan ini."

Jawapan:

Malangnya, tindakan yang diingini tidak boleh dilakukan menggunakan pencetus. Pencetus MySQL dikekang dalam keupayaan mereka untuk mengemas kini jadual yang sama tempat mereka dipanggil. Had ini dikenakan untuk mengelakkan isu integriti data yang mungkin timbul daripada kemas kini serentak.

Pendekatan yang disyorkan untuk mencapai kefungsian yang diingini ialah mencipta prosedur tersimpan yang merangkumi kedua-dua operasi sisipan dan kemas kini dalam satu transaksi. Ini memastikan bahawa pangkalan data kekal dalam keadaan yang konsisten sepanjang proses.

Atas ialah kandungan terperinci Bolehkah MySQL Triggers Mengemas kini Jadual Sama Yang Dipanggil Mereka?. 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!