不知道为什么我得到这个PHP警告消息。在准备好的语句中似乎有四个参数,在bind_param()中也有四个变量。谢谢你的帮助!
if($stmt = $mysqli -> prepare("SELECT url, month, year, cover_image FROM back_issues ORDER BY year DESC, month DESC")) {
$stmt -> bind_param("ssis", $url, $month, $year, $cover_image);
$stmt -> execute();
$stmt -> bind_result($url, $month, $year, $cover_image);
$stmt -> fetch();
while ($stmt->fetch()) {
echo "<li class='item'><a href='$url'><img src='$cover_image' alt='$cover_image' width='' height='' /></a><br /><span class='monthIssue'>$month $year</span></li>";
}
$stmt -> close();
$mysqli -> close();
}
if($stmt = $mysqli -> prepare("SELECT url, month, year, cover_image FROM back_issues ORDER BY year DESC, month DESC")) {
$stmt -> bind_param("ssis", $url, $month, $year, $cover_image);
[...]
}
这些行没有任何意义!如果你想使用参数,你必须使用它们到where
条件或类似的,很像:
$mysqli->prepare("SELECT * FROM back_issues WHERE url =? AND month =? AND year =? and cover_image = ?");
$stmt->bind_param("ssis", $url, $month, $year, $cover_image);
如果您没有任何占位符与参数绑定,bind_param()
方法将产生您正在运行的错误。此外,IF语句应该做什么?如果您想验证该查询是否产生任何结果,您必须首先运行它,然后验证。
在这种情况下不需要绑定参数。占位符用于INSERT语句或WHERE子句中的值。(请注意,标识符不允许使用占位符,例如语句中的列名。)带占位符的有效简化语句如下:
"SELECT url, cover_image FROM back_issues WHERE month = ? and year = ?"