带有“变量”<>“或”变量“的 PHP/MySQL SELECT 语句不是空的,不起作用


PHP/MySQL SELECT statement with 'variable' <> ' ' or 'variable' IS NOT NULL not working

我编写了一个SQL例程,将用户的输入与表中的现有值进行比较。如果该值存在,则输入旁边会显示一个绿色复选标记。如果没有,则会出现一个红色的 x。我的 SQL 语句如下:

      $check = $con->prepare("SELECT count(*) FROM emaillist");
      $check->execute();
      $result = $check->fetchColumn(); //Get no. of columns
      $check = $con->prepare("SELECT Username FROM emaillist WHERE Username =                                                                                                                                                                                                                               
              '$Name' AND '$Name' <> '' ");
      $check->execute();
      $result = $check->fetchColumn(); //Get exact column
      if(!$result) {
               show red x } else { show green check }

只要有输入,这就可以正常工作。当输入不匹配时,红色 x 出现,当匹配匹配时,绿色复选标记出现;但是,如果字段留空,我不希望显示任何内容。现在,如果字段为空或为空,则会显示红色 x。使用 IS NOT NULL 也不起作用。我错过了什么?

您只有两个分支:显示红色 x 和显示绿色复选标记。 您需要第三个,例如

if (!$Name) {
    //show nothing
}
else if (!$result) {
    //show red x
}
else {
    //show green check
}

在不相关的说明中,您使用PDO很好,但您需要正确参数化查询以确保安全注入。

尝试像这样重写你的逻辑:

if ($Name != ''){
    $check = $con->prepare("SELECT Username FROM emaillist WHERE Username = '$Name'");
    $check->execute();
    $result = $check->fetchColumn(); //Get exact column
    if(!$result) {
          // show red x 
    } else { 
         // show green check 
    }
}
else {
    // show red here or some other input error message
}