0

我不确定是否有类似的问题,因为我不确定要搜索什么,但无论如何。

在我进行查询(有 1 个表)之后,有两种方法可以检查是否返回了一行:

$a = $members->prepare("select userid from users where userid = ?");
$a->bind_param('s', $_SESSION['token']);
$a->execute();
$a->store_result();
if ($a->num_rows == 1) {
    // do something
}

或者:

$b = $members->prepare("select userid from users where userid = ?");
$b->bind_param('s', $_SESSION['token']);
$b->execute();
$b->bind_result($uid);
$b->fetch();
if (isset($uid)) {
    // do something
}

哪一个最好用于查看是否返回了一行?我认为因为 num_rows 是为此目的而存在的,所以应该使用它,但是您必须存储结果集,所以我不确定,谢谢。

4

2 回答 2

1

第一个选项可能是最好的。顺便说一句,来自 php.net:

如果查询没有返回结果集,mysqli_store_result() 返回 FALSE

如果读取结果集失败,此函数也会返回 FALSE。

所以你也可以说:

if ($a->store_result()) {
    // do something
}
于 2012-05-25T18:52:13.250 回答
0

将 LIMIT 0,1 添加到 sql 查询中,您可以使用您喜欢的那个。但我更喜欢第一个。

于 2012-05-25T18:49:15.517 回答