Rumah > pangkalan data > tutorial mysql > Mengapa ID Auto-Increment Saya Tidak Meningkat dengan ON DUPLICATE KEY UPDATE dalam MySQL?

Mengapa ID Auto-Increment Saya Tidak Meningkat dengan ON DUPLICATE KEY UPDATE dalam MySQL?

Mary-Kate Olsen
Lepaskan: 2024-12-03 07:35:10
asal
673 orang telah melayarinya

Why Doesn't My Auto-Increment ID Increase with ON DUPLICATE KEY UPDATE in MySQL?

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:

  • Untuk mengekalkan jujukan ID tanpa celah, lebih banyak mekanisme mahal yang melibatkan penguncian meja dan penomboran semula adalah diperlukan.
  • Menggunakan nilai tambahan yang dikira pada output boleh memberikan penyelesaian yang lebih cekap dan fleksibel.

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!

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