Kemas Kini Bersyarat dalam INSERT ... ON DUPLICATE KEY UPDATE
Dalam MySQL, sintaks INSERT ... ON DUPLICATE KEY UPDATE membenarkan untuk kemas kini automatik data jadual apabila kunci pendua ditemui semasa operasi sisipan. Walau bagaimanapun, bahagian UPDATE pertanyaan tidak menyokong penggunaan klausa WHERE untuk menyatakan kemas kini bersyarat.
Penyelesaian Menggunakan IF()
Untuk mengatasi had ini, seseorang boleh menggunakan fungsi IF() untuk melaksanakan kemas kini bersyarat dalam klausa ON DUPLICATE KEY UPDATE. Fungsi IF() menilai keadaan dan mengembalikan nilai yang berbeza berdasarkan hasil.
Sebagai contoh, pertimbangkan INSERT berikut ... PADA penyataan KEMASKINI KUNCI DUA:
INSERT INTO daily_events (created_on, last_event_id, last_event_created_at) VALUES ('2010-01-19', 23, '2010-01-19 10:23:11') ON DUPLICATE KEY UPDATE last_event_id = IF(last_event_created_at < VALUES(last_event_created_at), VALUES(last_event_id), last_event_id);
Dalam penyataan ini, fungsi IF() menyemak sama ada nilai lajur last_event_created_at dalam jadual pangkalan data adalah kurang daripada nilai yang dimasukkan (VALUES(last_event_created_at)). Jika benar, ia mengemas kini lajur last_event_id dengan nilai baharu daripada penyata sisipan. Jika tidak, ia membiarkan nilai sedia ada tidak berubah.
Penyelesaian ini membenarkan kemas kini bersyarat dalam INSERT ... PADA penyataan KEMASKINI KUNCI DUA tanpa menggunakan gabungan pertanyaan INSERT/UPDATE/SELECT, yang mungkin tidak sesuai untuk replikasi senario.
Atas ialah kandungan terperinci Bagaimana untuk Melakukan Kemas Kini Bersyarat dalam INSERT MySQL ... PADA KEMASKINI KUNCI DUA?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!