首頁 後端開發 php教程 PDO中錯誤處理的方法二-errorInfo()方法

PDO中錯誤處理的方法二-errorInfo()方法

Apr 28, 2017 pm 05:45 PM

PDO中錯誤處理的方法二-errorInfo()方法

#PDOStatement::errorInfo — 取得跟上一次語句句柄操作相關的擴充錯誤訊息(PHP 5 >= 5.1.0, PECL pdo >= 0.1.0)!

在上一篇文章《PDO中錯誤處理的方法一-errorCode()方法》中我們介紹了PDO中錯誤處理的第一種方法,大家可以在上一在文章回顧下,接下來我們為大家介紹PDO中錯誤處理的第二種方法~

errorInfo()方法用來取得操作資料庫句柄時所發生的資訊錯誤,該方法的語法格式如下:

array PDOStatement::errorInfo(void)
登入後複製

PDOStatement::errorInfo() 傳回一個關於上一次語句句柄執行操作的錯誤訊息的陣列。此陣列包含下列欄位:

元素訊息
0SQLSTATE 錯誤碼(一個由5個字母或數字組成的在ANSI SQL 標準中定義的識別碼)。
1具體驅動錯誤碼。
2具體驅動錯誤訊息。

在PDO中透過query()方法完成資料的查詢操作,並且透過foreach 語句完成資料的循環輸出,在定義SQL 語句的時候使用一個錯誤的數據表,並且透過errorInfo()方法傳回錯誤訊息,具體實作步驟如下:

建立一個php文件,先透過PDO 連接MySQL資料庫,然後透過query()方法執行查詢語句,接著透過errorInfo()方法取得錯誤訊息,最後透過foreach 語句完成資料的循環輸出,具體實作程式碼如下:

<?php
header("Content-Type:text/html; charset=utf-8");    //设置页面的编码格式
$dbms = "mysql";                                  // 数据库的类型
$dbName ="php_cn";                                //使用的数据库名称
$user = "root";                                   //使用的数据库用户名
$pwd = "root";                                    //使用的数据库密码
$host = "localhost";                              //使用的主机名称
$dsn  = "$dbms:host=$host;dbname=$dbName";
try{
$pdo=new PDO($dsn,$user,$pwd);//初始化一个PDO对象,就是创建了数据库连接对象$pdo
$query="select * from user_12";//需要执行的sql语句
$res=$pdo->query($query);//准备查询语句
print_r($pdo->errorInfo());
?>
<table border="1" width="500">
    <tr>
        <td height="22" align="center" valign="middle">id</td>
        <td height="22" align="center" valign="middle">用户名</td>
        <td height="22" align="center" valign="middle">密码</td>
    </tr>
    <?php
    foreach ($res as $items){
        ?>
        <tr>
            <td height="22" align="center" valign="middle"><?php echo $items["id"];?></td>
            <td height="22" align="center" valign="middle"><?php echo $items["username"];?></td>
            <td height="22" align="center" valign="middle"><?php echo $items["password"];?></td>
        </tr>
        <?php
    }
    }catch(PDOException $e){
        die("Error!:".$e->getMessage().&#39;<br>&#39;);
    }
    ?>
</table>
登入後複製

##注意:

在上面的程式碼中,在定義SELECT 查詢語句的時候,我們故意使用了錯誤的資料表名字user_12(正確的資料表名稱是:user),這裡是為了測試寫的!

輸出的結果如下圖所示:

PDO中錯誤處理的方法二-errorInfo()方法

#關於PDO中錯誤處理的兩種方法到這裡我們就全部介紹完了,相信小夥伴們對PDO中錯誤處理有了一定了解,還沒明白的小伙伴可以再回顧一下,下一篇文章我們繼續給大家介紹PDO的事務處理,具體請閱讀《

PDO中的事務處理具體介紹》!

以上是PDO中錯誤處理的方法二-errorInfo()方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

使用中間件改善golang函數中的錯誤處理 使用中間件改善golang函數中的錯誤處理 Apr 24, 2024 pm 06:57 PM

使用中間件改善Go函數中的錯誤處理:引入中間件的概念,它可以攔截函數呼叫並執行特定邏輯。建立錯誤處理中間件,該中間件將錯誤處理邏輯包裝在自訂函數中。使用中間件包裝處理程序函數,以便在函數呼叫之前執行錯誤處理邏輯。根據錯誤類型返回適當的錯誤代碼,улучшениеобработкиошибоквфункцияхGoспомощьюпромежуто намсосредоточитьсянаобработкеошибо

透過異常處理,如何在 C++ 中有效處理錯誤場景? 透過異常處理,如何在 C++ 中有效處理錯誤場景? Jun 02, 2024 pm 12:38 PM

在C++中,異常處理透過try-catch區塊優雅地處理錯誤,常見的異常類型包括執行時間錯誤、邏輯錯誤和超出界限錯誤。以檔案開啟錯誤處理為例,當程式開啟檔案失敗時,它會拋出異常,並透過catch區塊列印錯誤訊息和傳回錯誤程式碼,從而在不終止程式的情況下處理錯誤。異常處理提供錯誤處理集中化、錯誤傳遞和程式碼健全性等優勢。

C++類別設計中如何進行錯誤處理與記錄? C++類別設計中如何進行錯誤處理與記錄? Jun 02, 2024 am 09:45 AM

C++類別設計中的錯誤處理和日誌記錄包括:異常處理:捕獲並處理異常,使用自訂異常類別提供特定錯誤訊息。錯誤碼:使用整數或枚舉表示錯誤條件,在回傳值中傳回。斷言:驗證預置和後置條件,不成立時引發異常。 C++函式庫日誌:使用std::cerr和std::clog進行基本日誌記錄。外部日誌庫:整合第三方庫以獲得高級功能,如等級過濾和日誌檔案旋轉。自訂日誌類:建立自己的日誌類,抽象底層機制,提供通用介面記錄不同等級資訊。

PHP 錯誤處理中的最佳工具和函式庫? PHP 錯誤處理中的最佳工具和函式庫? May 09, 2024 pm 09:51 PM

PHP中最佳的錯誤處理工具和庫包括:內建方法:set_error_handler()和error_get_last()第三方工具包:Whoops(調試和錯誤格式化)第三方服務:Sentry(錯誤報告和監控)第三方庫: PHP-error-handler(自訂錯誤日誌記錄和堆疊追蹤)和Monolog(錯誤日誌記錄處理器)

golang函數錯誤處理中的非同步處理 golang函數錯誤處理中的非同步處理 May 03, 2024 pm 03:06 PM

在Go函數中,非同步錯誤處理透過使用error通道,非同步地從goroutine傳遞錯誤。具體步驟如下:建立一個error頻道。啟動一個goroutine來執行操作並非同步發送錯誤。使用select語句從通道接收錯誤。非同步處理錯誤,例如列印或記錄錯誤訊息。此方法可以提高並發程式碼的效能和可擴展性,因為錯誤處理不會阻塞呼叫線程,並且可以取消執行。

Go 函數單元測試的錯誤處理策略 Go 函數單元測試的錯誤處理策略 May 02, 2024 am 11:21 AM

在Go函數單元測試中,錯誤處理有兩種主要策略:1.將錯誤表示為error類型的具體值,用於斷言預期值;2.使用通道向測試函數傳遞錯誤,適用於測試並發程式碼。實戰案例中,使用錯誤值策略確保函數對負數輸入回傳0。

golang函數的錯誤處理的最佳實踐 golang函數的錯誤處理的最佳實踐 Apr 24, 2024 pm 05:24 PM

Go中的錯誤處理最佳實務包括:使用error類型、始終傳回錯誤、檢查錯誤、使用多值傳回、使用sentinel錯誤、使用錯誤包裹。實作案例:在HTTP請求處理程序中,如果ReadDataFromDatabase回傳錯誤,則傳回500錯誤回應。

如何使用 Golang 的錯誤包裝器? 如何使用 Golang 的錯誤包裝器? Jun 03, 2024 pm 04:08 PM

在Golang中,錯誤包裝器允許你在原始錯誤上追加上下文訊息,從而創建新錯誤。這可用於統一不同程式庫或元件拋出的錯誤類型,簡化偵錯和錯誤處理。步驟如下:使用errors.Wrap函數將原有錯誤包裝成新錯誤。新錯誤包含原始錯誤的上下文資訊。使用fmt.Printf輸出包裝後的錯誤,提供更多上下文和可操作性。在處理不同類型的錯誤時,使用errors.Wrap函數統一錯誤類型。

See all articles