Rumah  >  Artikel  >  pangkalan data  >  Bagaimana untuk Melakukan Kemas Kini Bersyarat dalam INSERT MySQL ... PADA KEMASKINI KUNCI DUA?

Bagaimana untuk Melakukan Kemas Kini Bersyarat dalam INSERT MySQL ... PADA KEMASKINI KUNCI DUA?

Linda Hamilton
Linda Hamiltonasal
2024-10-31 00:13:30443semak imbas

How to Perform Conditional Updates in MySQL's INSERT ... ON DUPLICATE KEY UPDATE?

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!

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