为什么我所有的查询都能工作,除了这个?尽管没有在PHP中工作,但它在终端中工作良好
我有以下代码块:为什么我所有的查询都能工作,除了这个?尽管没有在PHP中工作,但它在终端中工作良好,php,mysql,mysqli,Php,Mysql,Mysqli,我有以下代码块: $result = $db->query("SELECT username FROM users WHERE id = 1"); while ($row = $result->fetch_assoc()) { echo $row["username"]; } 但这不起作用,我得到了一个可怕的致命错误:致命错误:对非对象调用成员函数fetch_assoc() 但是,如果我在Sequel Pro之类的程序中运行它,我会得到以下结果: 另外,所有其他检索语句都在
$result = $db->query("SELECT username FROM users WHERE id = 1");
while ($row = $result->fetch_assoc()) {
echo $row["username"];
}
但这不起作用,我得到了一个可怕的致命错误:致命错误:对非对象调用成员函数fetch_assoc()
但是,如果我在Sequel Pro之类的程序中运行它,我会得到以下结果:
另外,所有其他检索语句都在我的代码中工作。只是不是这个。我做错了什么?该错误似乎表明$db未初始化,或者$result为空。。。你在这个循环中做了一些假设,但对于其中一个变量实际包含的内容,这些假设是不正确的。为什么不检查错误呢?这有一个函数。我知道它返回了一个错误,我的问题是它不应该返回,正如我在上面强调的。语句应该返回数据。这听起来可能很愚蠢,但您是否用代码连接到数据库?$db是mysqli对象,是吗?在查询之前,请尝试预先添加以下内容:
if(mysqli_connect_errno()){printf(“连接失败:%s\n”,mysqli_connect_error());exit()}
或者,在while循环之前:printf(“错误:%d.\n”,mysqli_stmt_error($db))正如我所说,我在前面检索了一些值,因此$db肯定会被初始化。而且,它甚至没有进入循环。@DougSmith它没有进入循环,因为循环的条件是返回错误的条件。你是否检查了你在上一个问题中被问到的问题?