使用 PDO 準備查詢時,擷取任何相關錯誤可能非常重要。這對於調試目的或處理意外的資料庫互動特別有用。
考慮以下PHP 程式碼片段:
$st = $db->prepare("SELECT * FROM c6ode");
在這種情況下,如果查詢包含任何錯誤(例如不存在的表),可能不確定如何檢索和處理這些錯誤。
要從prepare()方法檢索查詢錯誤,需要配置PDO以在錯誤時拋出異常。這是透過將 PDO::ATTR_ERRMODE 屬性設為 PDO::ERRMODE_EXCEPTION 來實現的。
此外,為了確保 MySQL 伺服器在準備階段驗證查詢,停用 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 (?)');
執行此程式碼時,將引發異常,其中包含以下詳細資訊:
SQLSTATE[42S02]: Base table or view not found: 1146 Table 'test.doesnotexist' doesn't exist
透過適當配置PDO,可以有效地捕獲和處理查詢錯誤,確保高效的調試和資料庫交互。
以上是如何從 PDO 的「prepare()」方法檢索和處理查詢錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!