Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Mengabaikan Sisipan Kunci Pendua dalam SQL Tanpa Ralat?

Bagaimana untuk Mengabaikan Sisipan Kunci Pendua dalam SQL Tanpa Ralat?

Patricia Arquette
Lepaskan: 2024-11-27 16:05:11
asal
896 orang telah melayarinya

How to Ignore Duplicate Key Inserts in SQL Without Errors?

Bagaimana untuk Mengabaikan Kekunci Pendua pada Sisipan?

Anda cuba memasukkan data ke dalam jadual di mana medan teg mempunyai kekangan UNIK . Untuk mengabaikan sebarang teg pendua, anda mencari penyelesaian yang mengabaikan sisipan pendua ini.

Penyelesaian:

Daripada menggunakan INSERT IGNORE, yang menyekat semua ralat, pertimbangkan untuk menggunakan mengikuti pendekatan:

INSERT INTO table_tags (tag) VALUES ('tag_a'),('tab_b'),('tag_c')
ON DUPLICATE KEY UPDATE tag=tag;
Salin selepas log masuk

Penjelasan:

Dengan menggunakan ON DUPLICATE KEY UPDATE, jika mana-mana teg sudah wujud dalam pangkalan data, nilainya tidak akan dikemas kini. Ini bermakna sisipan pendua akan diabaikan tanpa menyebabkan ralat. Kod yang anda berikan dengan "*" tidak akan berfungsi kerana ia tidak menyatakan teg mana yang harus diabaikan.

Contoh:

Apabila anda melaksanakan pertanyaan di atas, anda akan perasan bahawa mesej berikut dipaparkan:

Query OK, 0 rows affected (0.07 sec)
Salin selepas log masuk

Ini menunjukkan bahawa data telah berjaya dimasukkan, dengan sebarang pendua tag diabaikan.

Atas ialah kandungan terperinci Bagaimana untuk Mengabaikan Sisipan Kunci Pendua dalam SQL Tanpa Ralat?. 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