防止在php / mysql中重复插入行

时间:2010-02-25 02:28:12

标签: php sql mysql

如何防止在php mysql中输入重复记录?在插入表格之前验证输入。

我目前正在为我的网站构建用户注册部分,但如果在数据库中找到重复的用户名或电子邮件地址,则希望向他们显示错误。

修改
这就是我要插入行的方法......我将如何在这里实现这两个答案:

  <?php
        if (array_key_exists('confirm',$_POST)) {

                $Cuser = $_POST['Cuser']; 
                $Cemail = $_POST['Cemail']; 
                $Cpassword = $_POST['Cpassword'];
                $md5password = md5($_POST['Cpassword']);

                mysql_query("INSERT INTO tbl_users (`username`,`email`,`password`)
VALUES ('$Cuser', '$Cemail', '$md5password')"); 

                echo "Thank you. The user <b>".$Cuser."&nbsp;(".$Cemail.")</b> has been successfully added to the database.<p>

                <a href='myaccount.php' class='form'>Return</a>";       

                exit;
        }
        ?>

我猜我可以在if ... else语句中实现它吗?

3 个答案:

答案 0 :(得分:17)

为用户名和电子邮件列定义唯一约束:

ALTER TABLE your_table ADD CONSTRAINT uk_username UNIQUE (username)
ALTER TABLE your_table ADD CONSTRAINT uk_email UNIQUE (email)

如果表中已经存在试图插入或更新的值,MySQL将返回一个错误,指出查询违反了相应的唯一约束(可能两者都有)。由你来设置PHP来优雅地处理它。

答案 1 :(得分:3)

在插入之前,运行类似

的SQL语句
SELECT * FROM users WHERE users.name = :name OR users.email = :email

(使用parametrized SQL)并计算返回的行数。

如果超过0,则会有重复。

OMG Ponies建议对这两个字段进行约束,这也是防止您在数据库中出错的一个好主意。但是,如果您插入重复项,则所有该约束都将使您获得一条数据库错误消息,您可能想要或可能不想尝试解析该消息。

答案 2 :(得分:1)

我使用sql语句和if else语句。

mysql_select_db($database_speedycms, $speedycms);
$query_usercheck = "SELECT * FROM tbl_users WHERE username='$user' OR email='$email'";
$usercheck = mysql_query($query_usercheck, $speedycms) or die(mysql_error());
$row_usercheck = mysql_fetch_assoc($usercheck);
$totalRows_usercheck = mysql_num_rows($usercheck);

然后

if ( $totalRows_usercheck > 0 )

显示错误消息以防止添加任何重复

否则允许数据库插入