如何在 PDO PHP 中查看查询错误

Posted

技术标签:

【中文标题】如何在 PDO PHP 中查看查询错误【英文标题】:How to view query error in PDO PHP 【发布时间】:2012-02-05 06:36:02 【问题描述】:
try 
    $db = new PDO("mysql:host=".HOST.";dbname=".DB, USER, PW);
    $st = $db->prepare("SELECT * FROM c6ode");

catch (PDOException $e)
    echo $e->getMessage();

在上述情况下,如何检查查询的 mysql 错误?

【问题讨论】:

【参考方案1】:

您需要将错误模式属性 PDO::ATTR_ERRMODE 设置为 PDO::ERRMODE_EXCEPTION。 由于您希望prepare() 方法抛出异常,您应该禁用PDO::ATTR_EMULATE_PREPARES* 功能。否则 MySQL 服务器在执行之前不会“看到”该语句。

<?php
try 
    $pdo = new PDO('mysql:host=localhost;dbname=test;charset=utf8', 'localonly', 'localonly');
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    $pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);


    $pdo->prepare('INSERT INTO DoesNotExist (x) VALUES (?)');

catch(Exception $e) 
    echo 'Exception -> ';
    var_dump($e->getMessage());

打印(以我为例)

Exception -> string(91) "SQLSTATE[42S02]: Base table or view not found: 
1146 Table 'test.doesnotexist' doesn't exist"

见http://wezfurlong.org/blog/2006/apr/using-pdo-mysql/ EMULATE_PREPARES=true 现在似乎是 pdo_mysql 驱动程序的默认设置。 从那时起,查询缓存的事情已经修复/更改,并且使用 mysqlnd 驱动程序我对 EMULATE_PREPARES=false 没有任何问题(虽然我只是一个 php 爱好者,但不要相信我的话......)

*) 然后是PDO::MYSQL_ATTR_DIRECT_QUERY - 我必须承认我不了解这两个属性的交互(还没有?),所以我将它们都设置了,比如

$pdo = new PDO('mysql:host=localhost;dbname=test;charset=utf8', 'localonly', 'localonly', array(
    PDO::ATTR_EMULATE_PREPARES=>false,
    PDO::MYSQL_ATTR_DIRECT_QUERY=>false,
    PDO::ATTR_ERRMODE=>PDO::ERRMODE_EXCEPTION
));

【讨论】:

【参考方案2】:

我使用这个没有任何额外的设置:

if (!$st->execute()) 
    print_r($st->errorInfo());

【讨论】:

8 年后仍然是最佳答案 适合 2021 年【参考方案3】:

我猜你的抱怨是异常没有触发。 PDO 很可能配置为不引发异常。启用它们:

$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); 

【讨论】:

不行还是不行,我知道我的查询是错误的,但我想显示那个错误。 您可能会发现调用new PDO(... 本身存在错误。尝试通过设置例如 error_reporting(E_ALL) 来提高 error_reporting 的级别。【参考方案4】:

在测试时查看错误的快速方法:

$error= $st->errorInfo();
echo $error[2];

【讨论】:

我觉得这个方法很简单【参考方案5】:

/*引发错误——BONES表不存在*/

$sth = $dbh->prepare('SELECT skull FROM bones');
$sth->execute();

echo "\nPDOStatement::errorInfo():\n";
$arr = $sth->errorInfo();
print_r($arr);

输出

Array
(
    [0] => 42S02
    [1] => -204
    [2] => [IBM][CLI Driver][DB2/LINUX] SQL0204N  "DANIELS.BONES" is an undefined name.  SQLSTATE=42704
)

【讨论】:

未捕获错误:调用未定义函数errorInfo()

以上是关于如何在 PDO PHP 中查看查询错误的主要内容,如果未能解决你的问题,请参考以下文章

如何在 PHP 中使用带有 PDO 的 MySQL 用户函数?

在带有 PDO 的 PHP 中,如何检查最终的 SQL 参数化查询? [复制]

在带有 PDO 的 PHP 中,如何检查最终的 SQL 参数化查询? [复制]

如何查看准备好的 PDO SQL 语句 [重复]

在 PHP 中,当将 PDO 与 pgSQL 一起使用时,如何在原始 INSERT sql 查询中获取“RETURNING”子句的值

如何在 PHP PDO 查询中插入“now() -interval '2 minutes'”之类的内容?