Anda dapat memodifikasi INSERT Anda menjadi seperti ini:
INSERT INTO tablename (tag)
SELECT $tag
FROM tablename
WHERE NOT EXISTS(
SELECT tag
FROM tablename
WHERE tag = $tag
)
LIMIT 1
Dimana $tag
adalah tag (dikutip dengan benar atau sebagai pengganti tentu saja) yang ingin Anda tambahkan jika belum ada di sana. Pendekatan ini bahkan tidak akan memicu INSERT (dan pemborosan peningkatan otomatis berikutnya) jika tag sudah ada di sana. Anda mungkin bisa membuat SQL yang lebih bagus dari itu, tetapi cara di atas akan berhasil.
Jika tabel Anda diindeks dengan benar maka SELECT tambahan untuk pemeriksaan keberadaan akan cepat dan database tetap harus melakukan pemeriksaan itu.
Pendekatan ini tidak akan berfungsi untuk tag pertama. Anda dapat menyemai tabel tag dengan tag yang menurut Anda akan selalu digunakan atau Anda dapat melakukan pemeriksaan terpisah untuk tabel kosong.