$st = $db->prepare("SELECT * FROM c6ode");
在上面的例子中,我如何检查查询的故意mysql错误?
ki1q1bka1#
您需要将错误模式属性PDO::ATTR_ERRMODE设置为PDO::ERRMODE_EXCEPTION。由于您希望prepare()方法抛出异常,因此应该禁用PDO::ATTR_EMULATE_PREPARES特性,否则MySQL服务器在执行语句之前不会“看到”该语句。
PDO::ATTR_ERRMODE
PDO::ERRMODE_EXCEPTION
prepare()
PDO::ATTR_EMULATE_PREPARES
<?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
ohfgkhjo2#
我正在使用此选项,但没有任何其他设置:
if (!$st->execute()) { print_r($st->errorInfo()); }
zphenhs43#
我猜你抱怨的是异常没有触发。PDO很可能被配置为不抛出异常。使用以下命令启用它们:
$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
wf82jlnq4#
测试时查看错误的快速方法:
$error= $st->errorInfo(); echo $error[2];
hujrc8aj5#
/* 引发错误--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 )
5条答案
按热度按时间ki1q1bka1#
您需要将错误模式属性
PDO::ATTR_ERRMODE
设置为PDO::ERRMODE_EXCEPTION
。由于您希望
prepare()
方法抛出异常,因此应该禁用PDO::ATTR_EMULATE_PREPARES
特性,否则MySQL服务器在执行语句之前不会“看到”该语句。打印(或日志,取决于PHP设置)
ohfgkhjo2#
我正在使用此选项,但没有任何其他设置:
zphenhs43#
我猜你抱怨的是异常没有触发。PDO很可能被配置为不抛出异常。使用以下命令启用它们:
wf82jlnq4#
测试时查看错误的快速方法:
hujrc8aj5#
/* 引发错误--BONES表格不存在 */
输出