1

我正在将一些代码从旧的 mysql_* 函数更新到 PDO。它连接没有问题,运行查询没有问题,但结果集是空的。PDO::query() 应该返回一个 PDOStatement 对象,但我得到的回报是真实的。没有错误报告。

这是我的代码:


try
{
    $DB = new PDO("mysql:host=localhost;dbname=dbname", "user", "pass");
    $stmt = $DB->prepare("SELECT * FROM report_clientinfo");
    $stmt->execute();
}catch(PDOException $e)
{
    echo $e->getMessage() . "\n";
}


echo gettype($stmt) . "\n";
if ($stmt) echo "true\n";
else echo "false\n";

$resultset = $stmt->fetchAll();

if(empty($resultset))
{
    exit("ERROR: getClientInfo query failed.");
}

$DB = null;

print_r($resultset);

我看到的输出是:

object true 错误:getClientInfo 查询失败。

任何想法为什么它没有返回任何结果?

4

2 回答 2

5
object  
true  
ERROR: getClientInfo query failed.

在我看来,您的PDOStatement $stmt变量实际上被报告为一个对象,而不是“ true”。然后,当代码true看到它$stmt是非空的时,它会打印“”,因为它是一个对象。

我建议您检查从$stmt->execute(). 您可能遇到 SQL 错误。例如,如果您拼错了表名,或者该表在dbname您连接的数据库“ ”中不存在,或者您登录的用户没有权限查询该表。

还要检查$stmt->errorInfo()以获取有关发生的任何错误的更多详细信息。

于 2009-01-02T01:22:24.733 回答
0

我有点尴尬地报告说我指向了错误的 DSN。我想这就是我在跨年夜外出后仅仅几个小时的睡眠就尝试学习新东西的结果。感谢 PDOStatement::errorInfo() 方法的提示,我之前没有注意到它。

于 2009-01-02T03:31:20.090 回答