store_result() 和 get_result() 在 mysql returns 错误
store_result() and get_result() in mysql returns false
几天前我编写了一个代码,其中包括 get_result()
以从我的数据库中接收结果。今天我想添加到它并修复一些错误。所以我尝试使用 num_rows
来查看是否返回了任何内容。但是为此我不得不使用 store_result()
。当我这样做时 get_result()
只是 returns 布尔值 false。当我注释掉 store_result()
时,一切正常。
我知道 >=
会把事情搞砸。但是我把 =
放在那里进行调试(注释掉 store_result()
看看发生了什么)。所以这不是问题
$sql = $this->connect();
$a = $sql->prepare("SELECT `name`, `title`, `comment`, `date` FROM `comment` WHERE `post`=?");
$a->bind_param("s", $id);
$a->execute();
$a->store_result();
if ($a->num_rows >= 0) {
$res = $a->get_result();
var_dump($res);
while ($row = $res->fetch_assoc()) {
$results[] = $row;
}
return $results;
} else {
return false;
}
使用get_result()
代替 of store_result()
,然后使用结果对象的num_rows
:
$a->execute();
$res = $a->get_result();
if ($res->num_rows > 0) {
while ($row = $res->fetch_assoc()) {
$results[] = $row;
}
return $results;
} else {
return false;
}
几天前我编写了一个代码,其中包括 get_result()
以从我的数据库中接收结果。今天我想添加到它并修复一些错误。所以我尝试使用 num_rows
来查看是否返回了任何内容。但是为此我不得不使用 store_result()
。当我这样做时 get_result()
只是 returns 布尔值 false。当我注释掉 store_result()
时,一切正常。
我知道 >=
会把事情搞砸。但是我把 =
放在那里进行调试(注释掉 store_result()
看看发生了什么)。所以这不是问题
$sql = $this->connect();
$a = $sql->prepare("SELECT `name`, `title`, `comment`, `date` FROM `comment` WHERE `post`=?");
$a->bind_param("s", $id);
$a->execute();
$a->store_result();
if ($a->num_rows >= 0) {
$res = $a->get_result();
var_dump($res);
while ($row = $res->fetch_assoc()) {
$results[] = $row;
}
return $results;
} else {
return false;
}
使用get_result()
代替 of store_result()
,然后使用结果对象的num_rows
:
$a->execute();
$res = $a->get_result();
if ($res->num_rows > 0) {
while ($row = $res->fetch_assoc()) {
$results[] = $row;
}
return $results;
} else {
return false;
}