Rumah  >  Artikel  >  pangkalan data  >  Bagaimana untuk Mengemas kini Baris dalam Jadual Yang Sama Menggunakan Pencetus: Penyelesaian kepada Tempoh Masa Bertindih?

Bagaimana untuk Mengemas kini Baris dalam Jadual Yang Sama Menggunakan Pencetus: Penyelesaian kepada Tempoh Masa Bertindih?

Patricia Arquette
Patricia Arquetteasal
2024-10-28 17:15:29485semak imbas

How to Update Rows in the Same Table Using Triggers: A Solution to Overlapping Time Periods?

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:

  1. Sisipkan atau kemas kini baris baharu ke dalam jadual pisah.
  2. Kemas kini tarikh tamat baris sebelumnya dengan procKey yang sepadan dengan baris BARU dan tarikh tamat yang sepadan dengan tarikh akan datang (cth., 20501231) menjadi ADDDATE(NEW. startDate, -1).
  3. Serahkan transaksi untuk memastikan perubahan berterusan.

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!

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