加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 插入前检查重复项

发布时间:2020-12-13 18:22:41 所属栏目:PHP教程 来源:网络整理
导读:在插入数据库之前,我使用以下代码来检查重复项.对我来说,当名称,描述,价格,城市和结束日期匹配时,副本仅被视为重复. foreach($states_to_add as $item) { $dupesql = "SELECT COUNT(*) FROM table WHERE ( name = '$name' AND description = '$description'
在插入数据库之前,我使用以下代码来检查重复项.对我来说,当名称,描述,价格,城市和结束日期匹配时,副本仅被视为重复.
foreach($states_to_add as $item) {
    $dupesql = "SELECT 
                    COUNT(*) 
                FROM 
                    table 
                WHERE 
                    (   
                        name = '$name' 
                        AND description = '$description' 
                        AND manufacturer = '$manufacturer' 
                        AND city ='$city' 
                        AND price = '$price' 
                        AND enddate = '$end_date'
                    )";

    $duperaw = mysql_query($dupesql);

    if($duperaw > 0) {
        echo nl2br("$name already exists in $city n");
    } 
    else {
        $sql = "INSERT INTO table (..... (here go the values to be inserted)
        ....

在运行此检查之前定义每个值,我的结果总是在项目已存在时返回.我倾倒了“dupesql”并将命令复制/粘贴到phpmyadmin中,后者返回计数0.

您想要执行以下操作:
$dupesql = "SELECT * FROM table where (name = '$name' AND description = '$description' AND manufacturer = '$manufacturer' AND city ='$city' AND price = '$price' AND enddate = '$end_date')";

$duperaw = mysql_query($dupesql);

if (mysql_num_rows($duperaw) > 0) {
  //your code ...
}

有关更多信息,请参见Here.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读