$st = $db->prepare("SELECT * FROM c6ode");
如何检查上述情况下查询的故意 mysql 错误?
需要设置错误模式属性
PDO::ATTR_ERRMODE
为PDO::ERRMODE_EXCEPTION
。
并且由于您希望
prepare()
方法抛出异常,因此您应该禁用 PDO::ATTR_EMULATE_PREPARES
功能。否则 MySQL 服务器在执行之前不会“看到”该语句。
<?php
$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 (?)');
打印(或日志,取决于 PHP 设置)
SQLSTATE[42S02]: Base table or view not found:
1146 Table 'test.doesnotexist' doesn't exist
我在没有任何额外设置的情况下使用它:
if (!$st->execute()) {
print_r($st->errorInfo());
}
我猜你的抱怨是异常没有触发。 PDO 很可能被配置为不抛出异常。启用它们:
$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
在测试时查看错误的快速方法:
$error= $st->errorInfo();
echo $error[2];
/* 引发错误——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
)