百科狗-知识改变命运!

PDOStatement::errorCode() - PDOStatement类

百变鹏仔2年前 (2023-11-21)阅读数 26#技术干货
文章标签句柄

PDOStatement::errorCode() - PDOStatement类

PDOStatement::errorCode()

(PHP 5 >= 5.1.0, PHP 7, PECL pdo >= 0.1.0)

获取跟上一次语句句柄操作相关的 SQLSTATE

说明

PDOStatement::errorCode(void): string

返回值

与PDO::errorCode()相同,只是PDOStatement::errorCode()只取回 PDOStatement 对象执行操作中的错误码。

范例

取回一个 SQLSTATE 码


以上例程会输出:

PDOStatement::errorCode(): 42S02

参见

  • PDO::errorCode() 获取跟数据库句柄上一次操作相关的 SQLSTATE
  • PDO::errorInfo() Fetch extended error information associated with the last operation on the database handle
  • PDOStatement::errorInfo() 获取跟上一次语句句柄操作相关的扩展错误信息
Statement's errorCode() returns an empty string before execution, and '00000' (five zeros) after a sucessfull execution:

Neither this property nor the PDOStatement::errorInfo() properties are available if you create your own exception handler.
I am using PHP 5.2.4, PDO_INFORMIX 1.2.0.
Making this call at any point in the program after setting your own exception handler produces an error:
PHP Notice: Undefined property: PDOStatement::$errorCode in new_query.php on line
or
PHP Notice: Undefined property: PDOStatement::$errorInfo in new_query.php on line
But if I set the PDO to SILENT, only set error codes with:
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_SILENT)
Then process with if/else the call to this functions works fine. The examples below only do error checking to show the result codes of this function. Normally you would want more.
FAILS:
$dbh = new PDO("informix...")
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
try {
   $result = $dbh->query("asdfkjasdfkjasdfjk"); /* obvious sql error */
   if ($result) print "success!";
   }
catch
   {
   $myeCode = $dbh->errorCode();
   /* do stuff with error */
   };
$dbh=0;
The error handler gets called but knows nothing about $dbh->errorCode or $dbh->errorInfo.
WORKS:
$dbh = new PDO("informix...")
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_SILENT);
$result = $dbh->query("asdfkjasdfkjasdfjk"); /* obvious sql error */
if ($result) 
   {
   /* process result */
   print "success!";
   /* all done, didn't make any changes */
   $dbh->rollback();
   }
else
   {
   $myeCode = $dbh->errorCode();
   print_r($myeCode);
   };
$dbh=0; /* close connection */
I hope this helps someone else.
Cheers,
David

内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)
{if $zbp->Config('yd1125')->foot}