首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySQLi准备语句失败

MySQLi准备语句失败
EN

Stack Overflow用户
提问于 2012-01-04 23:24:16
回答 1查看 9.1K关注 0票数 0

我在我的脚本room.php中运行了两个查询。两者都使用MySQLi预准备语句,其代码如下所示:

代码语言:javascript
复制
/* Get room name */
$stmt = $mysqli->prepare('SELECT name FROM `rooms` WHERE r_id=?');
$stmt->bind_param('i', $roomID);
$stmt->execute();
$stmt->bind_result($roomName)

/* Add this user to the room */
$stmt = $mysqli->prepare('INSERT INTO `room_users` (r_id, u_id) VALUES (?, ?)');
$stmt->bind_param('ii', $roomID, $_SESSION['userID']);
$stmt->execute();

当我运行脚本时,我得到这个错误:

代码语言:javascript
复制
Fatal error: Call to a member function bind_param() on a non-object in C:\wamp\www\room.php on line 24

这是第二个查询。如果我从脚本中删除第一个查询,一切都会正常运行。同样,如果我删除第二个查询。这让我相信有问题,因为我重用了$stmt对象。如果我尝试使用$stmt2进行第二个查询,我仍然会得到错误。

我的所有数据库表和字段都存在,所以查询没有任何问题。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-01-04 23:44:02

所有mysqli函数/方法都可能失败,在这种情况下,它们将返回false。也就是说,如果prepare()失败,那么$stmt不是你可以调用的对象,而是一个布尔值(False)。您必须检查返回值并添加一些错误处理,例如

代码语言:javascript
复制
$stmt = $mysqli->prepare('SELECT name FROM `rooms` WHERE r_id=?');
if ( !$stmt ) {
    printf('errno: %d, error: %s', $mysqli->errno, $mysqli->error);
    die;
}

$b = $stmt->bind_param('i', $roomID);
if ( !$b ) {
    printf('errno: %d, error: %s', $stmt->errno, $stmt->error);
}

$b = $stmt->execute();
if ( !$b ) {
  and so on and on

请参阅http://docs.php.net/mysqli-stmt.errno等人的

在这种情况下,您可能会遇到这样的问题:在前一条语句仍有结果/结果集悬而未决的情况下,无法创建另一条语句。

请参阅http://docs.php.net/mysqli-stmt.close

关闭一条准备好的语句。mysqli_stmt_close()还释放语句句柄。如果当前语句有挂起或未读的结果,此函数将取消这些结果,以便可以执行下一个查询。

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8729278

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档