Memahami ON DUPLICATE KEY Update with Auto Increment
Isu Penerangan:
Memasukkan data ke dalam jadual dengan klausa ON DUPLICATE KEY UPDATE menghasilkan ID yang tidak dijangka kenaikan apabila nilai pendua ditemui. Khususnya, ID meningkat apabila sisipan awal, tetapi kekal sama apabila mencetuskan kemas kini.
Penjelasan:
Menurut dokumentasi MySQL, apabila ON DUPLICATE KEY UPDATE klausa digunakan, MySQL mula-mula mencuba operasi INSERT. Jika ini membawa kepada nilai kunci pendua, operasi KEMASKINI akan dilakukan. Walau bagaimanapun, untuk lajur kenaikan automatik, kenaikan berlaku hanya semasa operasi INSERT. Oleh itu, walaupun operasi KEMASKINI dicetuskan, nilai kenaikan automatik kekal sama.
Penyelesaian:
Untuk memastikan kenaikan automatik yang betul, ia bukan dinasihatkan untuk bergantung pada mempunyai jujukan ID tanpa celah. Sebaliknya, pertimbangkan untuk mengira dan mengurus nilai tambahan secara manual atau menggunakan fungsi AUTO_INCREMENT pada output.
Nota Tambahan:
Atas ialah kandungan terperinci Mengapa ID Auto-Increment Saya Tidak Meningkat dengan ON DUPLICATE KEY UPDATE dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!