Rumah  >  Artikel  >  pangkalan data  >  Bolehkah MySQL Triggers Mengemas kini Jadual Sama Yang Dipanggil Mereka?

Bolehkah MySQL Triggers Mengemas kini Jadual Sama Yang Dipanggil Mereka?

Susan Sarandon
Susan Sarandonasal
2024-10-29 04:00:02555semak imbas

 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!

Kenyataan:
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