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
鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com
免责声明:我们致力于保护作者版权,注重分享,当前被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!邮箱:344225443@qq.com)
图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!
内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)