Memasukkan Rekod dalam SQLite Apabila Ia Tidak Wujud: Meneroka JIKA TIDAK WUJUD
Dalam MS SQL Server, klausa IF NOT EXISTS ialah digunakan untuk memasukkan rekod secara bersyarat ke dalam jadual. Sebagai contoh, coretan kod berikut mencipta rekod baharu dalam jadual EVENTTYPE jika ia belum wujud:
IF NOT EXISTS(SELECT 1 FROM EVENTTYPE WHERE EventTypeName = 'ANI Received') INSERT INTO EVENTTYPE (EventTypeName) VALUES ('ANI Received');
Walau bagaimanapun, SQLite tidak menyokong klausa IF NOT EXISTS secara asli. Akibatnya, pembangun yang ingin memindahkan fungsi ini ke SQLite mungkin menghadapi cabaran.
Penyelesaian SQLite untuk Sisipan Bersyarat
Walaupun tiada sokongan langsung JIKA TIDAK WUJUD, terdapat adalah beberapa penyelesaian yang tersedia dalam SQLite. Satu pendekatan biasa ialah menggunakan pernyataan INSERT OR IGNORE:
INSERT OR IGNORE INTO EVENTTYPE (EventTypeName) VALUES 'ANI Received'
Pernyataan ini cuba memasukkan rekod ke dalam jadual EVENTTYPE, tetapi ia tidak menimbulkan ralat jika rekod sudah wujud.
Sebagai alternatif, anda boleh menggunakan gabungan pernyataan SELECT dan INSERT, seperti yang dilihat di bawah:
INSERT INTO EVENTTYPE (EventTypeName) SELECT 'ANI Received' WHERE NOT EXISTS (SELECT 1 FROM EVENTTYPE WHERE EventTypeName = 'ANI Received');
Kod ini mula-mula menyemak sama ada rekod sudah wujud menggunakan pernyataan SELECT. Jika ia tidak wujud, pernyataan INSERT dilaksanakan untuk menambah rekod baharu.
Atas ialah kandungan terperinci Bagaimana untuk Mensimulasikan SQL Server JIKA TIDAK WUJUD dalam SQLite untuk Sisipan Bersyarat?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!