Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Mendapatkan ID Baris Terjejas Selepas Sisipkan PADA KEMASKINI KUNCI DUA dalam MySQL?

Bagaimanakah Saya Boleh Mendapatkan ID Baris Terjejas Selepas Sisipkan PADA KEMASKINI KUNCI DUA dalam MySQL?

Patricia Arquette
Patricia Arquetteasal
2024-12-04 18:19:151018semak imbas

How Can I Retrieve the ID of an Affected Row After an INSERT ON DUPLICATE KEY UPDATE in MySQL?

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:

  1. Pastikan jadual anda mempunyai lajur AUTO_INCREMENT, seperti id.
  2. Gunakan sintaks pertanyaan berikut:
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!

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