3

这是我的表格:

<!DOCTYPE html>
<html>
  <head>
  </head>
  <body>
    <form action="register_ajax.php" method="get">
    <input type="text" name="email">
    <input type="submit" value="test">
    </form>
  </body>
</html>

这是我的 php 代码:

<?php
    $dbc = mysqli_connect("localhost","root","*******","continental_tourism") OR die(mysqli_connect_error());
    $email = $_GET['email'];
    $query = "SELECT email FROM customer_info WHERE email = '$email' ";
    $r = mysqli_query($dbc, $query) OR die(mysqli_error($dbc));
    if($r)
        echo "Email address exists!";
    else
        echo "sss";
?>

如果我输入正确的(数据库上的现有电子邮件)$r为真。但如果我输入不存在的电子邮件,那么也是$r如此。这是为什么?基本上我想检测空集。我该怎么做?

谢谢!

4

4 回答 4

14

$r只有在出现 SQL 错误时才会为假。否则它将始终返回一个对象,即使您的 SELECT 语句没有返回任何行。

用于mysqli_num_rows()计算返回的行数。零表示没有人使用该电子邮件地址。

if(mysqli_num_rows($r))
    echo "Email address exists!";
else
    echo "sss"; 
于 2012-04-17T15:45:17.963 回答
5

mysqli_query()如果查询成功,将始终返回 MySQLi 结果资源。TRUE当作为布尔值测试时,资源将始终评估为。

成功的查询不一定是返回结果的查询,它只是一个没有失败的查询。当出现错误时,查询被视为失败,例如 MySQL 服务器中的语法错误或处理错误 - 在这种情况下,它们将返回FALSE. 但是没有找到结果的查询仍然是一个成功的查询。

您需要使用mysqli_num_rows()来确定查询是否找到任何结果:

<?php
    $dbc = mysqli_connect("localhost","root","longhorn","continental_tourism") OR die(mysqli_connect_error());

    $email = $_GET['email'];

    $query = "SELECT email FROM customer_info WHERE email = '$email' ";

    $r = mysqli_query($dbc, $query) OR die(mysqli_error($dbc));

    if(mysqli_num_rows($r) > 0)
        echo "Email address exists!";
    else
        echo "sss"; 
?>
于 2012-04-17T15:47:17.457 回答
0

mysqli_queryfalse将在成功和失败时返回结果对象。未选择任何行不被视为失败。您可以使用mysqli_num_rows来检查返回的行数。

于 2012-04-17T15:48:54.953 回答
0

需要测试是否$r为真,以及行数是否大于 0。

以下作品:

if ($r and mysqli_num_rows($r) > 0) {

  echo "rows exist"; } else {

echo "rows don't exist";  }
于 2018-08-08T10:47:56.647 回答