Rumah > Artikel > pembangunan bahagian belakang > Cara Mengendalikan Ralat Kemasukan Pendua dalam MySQL: INSERT...ABAIKAN, GANTIKAN KE DALAM, atau INSERT...PADA KEMASKINI KUNCI DUA?
Sisipan pangkalan data kadangkala boleh mengakibatkan ralat kemasukan pendua apabila cuba menambah rekod dengan pengecam unik. MySQL menyediakan beberapa alternatif untuk mengendalikan ralat tersebut.
Satu pilihan ialah menggunakan sintaks INSERT...IGNORE, yang menghalang penjanaan ralat sekiranya berlaku entri pendua. Ia hanya melangkau sisipan tanpa sebarang pemberitahuan.
Pendekatan lain ialah menggunakan REPLACE INTO, yang menggantikan rekod sedia ada dengan nilai kunci yang sama. Daripada mengabaikan sisipan, ia akan menimpa rekod lama dengan rekod baharu.
Akhir sekali, INSERT...PADA KEMASKINI KUNCI PENDULIK membolehkan operasi kemas kini dilakukan pada pertemuan kunci pendua. Ini bermakna daripada cuba memasukkan rekod baharu, MySQL akan mengemas kini rekod sedia ada dengan nilai yang disediakan.
Contoh:
Pertimbangkan jadual bernama tbl dengan lajur id dan nilai. Pada mulanya, ia mengandungi satu entri: id=1 dan nilai=1. Menjalankan penyataan berikut menunjukkan kelakuan setiap sintaks:
Atas ialah kandungan terperinci Cara Mengendalikan Ralat Kemasukan Pendua dalam MySQL: INSERT...ABAIKAN, GANTIKAN KE DALAM, atau INSERT...PADA KEMASKINI KUNCI DUA?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!