Mengemaskini Baris Lain dalam Jadual Yang Sama Menggunakan Pencetus
Masalahnya:
Mengekalkan rekod dengan tempoh masa bertindih selalunya memerlukan pengemaskinian tarikh tamat rekod terdahulu apabila rekod baharu dimasukkan dengan tarikh mula yang bertindih julat sedia ada.
Percubaan Asal:
Pencetus yang disediakan cuba mengemas kini endDate bagi baris sedia ada dengan nilai ADDDATE(NEW.startDate, -1) di mana procKey sepadan dengan baris BARU dan endDate ialah 20501231. Walau bagaimanapun, pendekatan ini mengakibatkan ralat "Tidak dapat mengemas kini jadual 'berpecah' dalam fungsi/pencetus tersimpan kerana ia sudah digunakan oleh pernyataan yang menggunakan fungsi/pencetus tersimpan ini."
Penyelesaian:
Malangnya, pencetus tidak boleh mengemas kini secara langsung baris lain dalam jadual yang sama dengan baris yang mencetuskan pencetus. Sebaliknya, pendekatan alternatif diperlukan.
Menggunakan Prosedur Tersimpan:
Buat prosedur tersimpan yang merangkumi logik berikut:
Pendekatan ini membenarkan kemas kini kepada berbilang baris dalam jadual yang sama dalam satu transaksi, mengelakkan konflik yang boleh timbul dengan pencetus.
Atas ialah kandungan terperinci Bagaimana untuk Mengemas kini Baris dalam Jadual Yang Sama Menggunakan Pencetus: Penyelesaian kepada Tempoh Masa Bertindih?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!