Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Mengelakkan Entri Pendua Apabila Memasukkan Data ke dalam SQLite?

Bagaimana untuk Mengelakkan Entri Pendua Apabila Memasukkan Data ke dalam SQLite?

Mary-Kate Olsen
Lepaskan: 2024-12-28 17:23:17
asal
173 orang telah melayarinya

How to Avoid Duplicate Entries When Inserting Data into SQLite?

Mengelakkan Sisipan Pendua dalam SQLite

SQLite, enjin pangkalan data ringan yang popular, tidak mempunyai sokongan eksplisit untuk klausa JIKA TIDAK WUJUD yang biasa ditemui di bahagian lain pelaksanaan SQL. Halangan ini boleh membingungkan pembangun yang biasa memanfaatkan kefungsian sedemikian untuk mengelakkan sisipan rekod pendua.

Untuk memintas pengehadan ini, SQLite menawarkan beberapa penyelesaian. Satu pendekatan ialah menggunakan perintah INSERT OR IGNORE:

INSERT OR IGNORE INTO EVENTTYPE (EventTypeName) VALUES ('ANI Received');
Salin selepas log masuk

Arahan ini akan memasukkan rekod baharu jika EventTypeName yang ditentukan belum wujud dalam jadual EVENTTYPE.

Pilihan lain ialah untuk menggunakan subquery dalam pernyataan INSERT:

INSERT INTO EVENTTYPE (EventTypeName)
SELECT 'ANI Received'
WHERE NOT EXISTS (SELECT 1 FROM EVENTTYPE WHERE EventTypeName = 'ANI Received');
Salin selepas log masuk

Pendekatan ini menyemak kewujudan rekod sebelum memasukkannya, dengan berkesan mencapai hasil yang sama seperti klausa JIKA TIDAK WUJUD.

Atas ialah kandungan terperinci Bagaimana untuk Mengelakkan Entri Pendua Apabila Memasukkan Data ke dalam SQLite?. 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