- Pertama.. karena @RamRaider sudah berkomentar, Anda harus menambahkan indeks unik ke
email
kolom - Kedua.. Anda harus berhenti menggunakan
mysql_*
berfungsi karena sudah usang. Anda dapat menggunakanmysqli_*
fungsi,MySQLi
kelas atauPDO
. Selain itu, dengan menggunakan pernyataan yang telah disiapkan, Anda menghindari Injeksi SQL -
Bahkan jika Anda menetapkan indeks unik, Anda harus selalu memverifikasi sebelum memasukkannya:
<?php // PDO instantiation here $stmt = $pdo->prepare('SELECT COUNT(email) AS EmailCount FROM emails WHERE email = :email'); $stmt->execute(array('email' => $_POST['email'])); $result = $stmt->fetch(PDO::FETCH_ASSOC); if ($result['EmailCount'] == 0) { $stmt = $pdo->prepare('INSERT INTO emails (email) VALUES (:email)'); $stmt->execute(array('email' => $_POST['email'])); echo 'Thank you for Submitting. Redirecting back to Home Page'; } else { echo 'E-mail exists!'; }