国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

PHP數(shù)據(jù)庫抽象層之PDO(五)——錯誤與錯誤處理

瀏覽:2日期:2022-09-15 16:12:06

PDO 提供了三種不同的錯誤處理模式,以滿足不同風格的應用開發(fā):

PDO::ERRMODE_SILENT此為默認模式。 PDO 將只簡單地設置錯誤碼,可使用?PDO::errorCode()?和?PDO::errorInfo()?方法來檢查語句和數(shù)據(jù)庫對象。如果錯誤是由于對語句對象的調(diào)用而產(chǎn)生的,那么可以調(diào)用那個對象的?PDOStatement::errorCode()?或?PDOStatement::errorInfo()?方法。如果錯誤是由于調(diào)用數(shù)據(jù)庫對象而產(chǎn)生的,那么可以在數(shù)據(jù)庫對象上調(diào)用上述兩個方法。PDO::ERRMODE_WARNING除設置錯誤碼之外,PDO 還將發(fā)出一條傳統(tǒng)的 E_WARNING 信息。如果只是想看看發(fā)生了什么問題且不中斷應用程序的流程,那么此設置在調(diào)試/測試期間非常有用。PDO::ERRMODE_EXCEPTION除設置錯誤碼之外,PDO 還將拋出一個?PDOException?異常類并設置它的屬性來反射錯誤碼和錯誤信息。此設置在調(diào)試期間也非常有用,因為它會有效地放大腳本中產(chǎn)生錯誤的點,從而可以非??焖俚刂赋龃a中有問題的潛在區(qū)域(記住:如果異常導致腳本終止,則事務被自動回滾)。

異常模式另一個非常有用的是,相比傳統(tǒng) PHP 風格的警告,可以更清晰地構(gòu)建自己的錯誤處理,而且比起靜默模式和顯式地檢查每種數(shù)據(jù)庫調(diào)用的返回值,異常模式需要的代碼/嵌套更少。

PDO 使用 SQL-92 SQLSTATE 來規(guī)范錯誤碼字符串;不同 PDO 驅(qū)動程序負責將它們的本地代碼映射為適當?shù)?SQLSTATE 代碼。?PDO::errorCode()?方法返回一個單獨的 SQLSTATE 碼。如果需要更多此錯誤的細節(jié)信息,PDO 還提供了一個?PDO::errorInfo()?方法來返回一個包含 SQLSTATE 碼、特定驅(qū)動錯誤碼以及此驅(qū)動的錯誤字符串的數(shù)組。

Example #1 創(chuàng)建 PDO 實例并設置錯誤模式

<?php $dsn = ’mysql:dbname=testdb;host=127.0.0.1’; $user = ’dbuser’; $password = ’dbpass’; try {$dbh = new PDO($dsn, $user, $password);$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); } catch (PDOException $e) {echo ’Connection failed: ’ . $e->getMessage(); }?>

不管當前是否設置了?PDO::ATTR_ERRMODE?,如果連接失敗,?PDO::__construct()?將總是拋出一個?PDOException?異常。未捕獲異常是致命的。

Example #2 創(chuàng)建 PDO 實例并在構(gòu)造函數(shù)中設置錯誤模式

<?php $dsn = ’mysql:dbname=test;host=127.0.0.1’; $user = ’googleguy’; $password = ’googleguy’; /* *使用 try/catch 圍繞構(gòu)造函數(shù)仍然有效,即使設置了 ERRMODE 為 WARNING, *因為如果連接失敗,PDO::__construct 將總是拋出一個 PDOException 異常。 */ try {$dbh = new PDO($dsn, $user, $password, array(PDO::ATTR_ERRMODE => PDO::ERRMODE_WARNING)); } catch (PDOException $e) {echo ’Connection failed: ’ . $e->getMessage();exit; }// 這里將導致 PDO 拋出一個 E_WARNING 級別的錯誤,而不是 一個異常 (當數(shù)據(jù)表不存在時)$dbh->query('SELECT wrongcolumn FROM wrongtable');?>

以上例程會輸出:

Warning: PDO::query(): SQLSTATE[42S02]: Base table or view not found: 1146 Table ’test.wrongtable’ doesn’t exist in/tmp/pdo_test.php on line 18

標簽: PHP
相關(guān)文章:
主站蜘蛛池模板: 模特精品一区二区三区 | 亚洲日本免费 | 三级大片在线观看 | 欧美kkk4444在线观看 | 13一14周岁毛片免费 | 日本韩国一级片 | 欧美久草在线 | 国产日韩欧美一区二区三区在线 | 中文字幕 亚洲 一区二区三区 | 狠狠ady精品| 亚洲综合综合在线 | 欧美私人网站 | 亚洲天堂视频在线观看免费 | 国产成人精品视频频 | 欧美日本俄罗斯一级毛片 | 看国产一级片 | 韩国福利影视一区二区三区 | 亚洲精品国产成人一区二区 | 中文字幕免费 | 免费萌白酱国产一区二区三区 | 国产伦久视频免费观看视频 | 九九综合九九 | 国产成年人视频 | 久99频这里只精品23热 视频 | 特级深夜a级毛片免费观看 特级生活片 | 国产乱码精品一区二区三区四川人 | 国产精品自在欧美一区 | 99精品免费久久久久久久久日本 | 国产v日韩v欧美v精品专区 | 玖玖精品在线 | 亚洲免费观看网站 | 黄色毛片在线 | 天堂中文字幕 | 特级a欧美孕妇做爰片毛片 特级a欧美做爰片毛片 | 狠狠色综合网站久久久久久久 | 欧美成人小视频 | 一个人看的免费观看日本视频www | 国产高清视频免费在线观看 | 国产va免费精品高清在线观看 | 国产精彩视频在线 | 九九久久免费视频 |