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

Linda Hamilton
Lepaskan: 2024-10-31 00:13:30
asal
441 orang telah melayarinya

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);
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!