Mendapatkan semula ID untuk Kemas Kini ON DUPLICATE KEY dalam MySQL
Apabila melaksanakan pertanyaan INSERT ON DUPLICATE KEY, mendapatkan ID baris yang terjejas boleh mencabar. Secara tradisinya, ini memerlukan menjalankan pertanyaan berasingan, kerana LAST_INSERT_ID() biasanya hanya mengembalikan ID untuk baris yang baru dimasukkan.
Walau bagaimanapun, terdapat penyelesaian yang memanfaatkan fungsi LAST_INSERT_ID(expr). Dengan menghantar ungkapan kepada fungsi ini, anda boleh menjadikan outputnya bermakna walaupun untuk baris yang dikemas kini.
Penyelesaian
Untuk mendapatkan semula ID baris yang dimasukkan atau dikemas kini menggunakan satu pertanyaan:
INSERT INTO table (a,b,c) VALUES (1,2,3) ON DUPLICATE KEY UPDATE>
Dengan menetapkan lajur id sebagai LAST_INSERT_ID(id) dalam klausa UPDATE, MySQL akan menyimpan nilai AUTO_INCREMENT baharu dalam lajur id untuk kedua-dua baris yang dimasukkan dan dikemas kini.
Ini membolehkan anda mendapatkan semula ID operasi terbaharu (sama ada sisipan atau kemas kini) dengan hanya memanggil LAST_INSERT_ID(). Ia menggabungkan kefungsian kedua-dua pernyataan INSERT dan UPDATE ke dalam satu pertanyaan dengan berkesan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mendapatkan ID Baris Terjejas Selepas Sisipkan PADA KEMASKINI KUNCI DUA dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!