Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Mencegah Kemas Kini Pendua dalam Pencetus MySQL Apabila Memasukkan Berbilang Baris?

Bagaimana untuk Mencegah Kemas Kini Pendua dalam Pencetus MySQL Apabila Memasukkan Berbilang Baris?

Barbara Streisand
Barbara Streisandasal
2024-11-29 06:38:13583semak imbas

How to Prevent Duplicate Updates in a MySQL Trigger When Inserting Multiple Rows?

MySQL Trigger untuk Kemas Kini Lajur dalam Jadual Lain selepas Dimasukkan

Dalam sistem pangkalan data hubungan, anda mungkin menghadapi keperluan untuk melaksanakan operasi secara automatik pada satu jadual apabila perubahan berlaku dalam jadual lain yang berkaitan. Di sinilah pencetus berguna. Dalam contoh khusus ini, kami menyasarkan untuk mencipta pencetus dalam MySQL yang mengemas kini lajur dalam jadual BookingRequest apabila baris baharu dimasukkan ke dalam jadual OccupiedRoom.

Pencetus yang anda tunjukkan cuba mengemas kini lajur status dalam Jadual BookingRequest terus selepas memasukkan baris ke dalam jadual OccupiedRoom. Walau bagaimanapun, isu dengan pendekatan ini ialah pencetus ditakrifkan untuk melaksanakan bagi setiap baris yang disisipkan dalam jadual OccupiedRoom, yang bermaksud bahawa ia akan dilaksanakan berbilang kali jika berbilang baris disisipkan secara serentak. Ini boleh membawa kepada kemas kini data yang tidak betul atau tidak konsisten.

Untuk menyelesaikan isu ini, kami perlu mengubah suai pencetus untuk hanya mengemas kini lajur status dalam jadual Permintaan Tempahan jika baris yang sepadan sudah wujud. Berikut ialah versi semakan bagi pencetus:

DELIMITER $$
CREATE TRIGGER occupy_trig
AFTER INSERT ON `OccupiedRoom` FOR EACH ROW
begin
  DECLARE id_exists Boolean;
  -- Check BookingRequest table
  SELECT 1
  INTO @id_exists
  FROM BookingRequest
  WHERE BookingRequest.idRequest= NEW.idRequest;

  IF @id_exists = 1
  THEN
    UPDATE BookingRequest
    SET status = '1'
    WHERE idRequest = NEW.idRequest;
  END IF;
END;
$$
DELIMITER ;

Pencetus ini menggunakan subkueri untuk menyemak sama ada baris yang sepadan wujud dalam jadual BookingRequest berdasarkan lajur idRequest. Jika baris yang sepadan ditemui, pencetus meneruskan untuk mengemas kini lajur status kepada '1'. Dengan memasukkan semakan ini, kami memastikan pencetus hanya mengemas kini baris yang berkaitan dalam jadual BookingRequest dan menghapuskan potensi kemas kini yang salah atau pendua.

Atas ialah kandungan terperinci Bagaimana untuk Mencegah Kemas Kini Pendua dalam Pencetus MySQL Apabila Memasukkan Berbilang Baris?. 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