Rumah > Artikel > pangkalan data > Bolehkah MySQL Triggers Mengemas kini Jadual Sama Yang Dipanggil Mereka?
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:
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!