從 PDO 準備語句取得原始 SQL 查詢
開發人員經常遇到需要偵錯透過 PDO 準備語句執行的 SQL 查詢的情況。雖然準備好的語句提供了各種好處,但取得在執行期間執行的原始 SQL 字串的存取權限是非常寶貴的。
PDO 可以提供原始 SQL 查詢嗎?
不幸的是,PDO並不會直接提供對準備好的語句中所使用的原始 SQL 查詢字串的存取。準備好的語句在資料庫伺服器內執行,並單獨傳送參數。因此,PDO 無法存取參數插值後的最終查詢字串。
替代方法
要取得原始的調試目的SQL 查詢,必須採用替代方法:
- MySQL 通用查詢日誌: MySQL 提供通用查詢記錄執行的查詢並回填參數值的日誌。
- PDO 模擬準備語句: 設定 PDO 屬性 PDO::ATTR_EMULATE_PREPARES 會導致 PDO 在執行前將參數插入 SQL 字串中。但是,這會損害真正的準備好的查詢方法。
注意:
PDOStatement 物件的 $queryString 屬性雖然在建構期間最初設定,但不會更新具有插值參數。將重寫的查詢作為 PDO 的功能改進公開是有益的,但它並不能解決真正準備好的查詢的限制。
結論
取得原始 SQL 查詢從 PDO 準備好的語句中取得字串並不是一個簡單的過程。替代方法(例如 MySQL 通用查詢日誌或模擬準備語句)為調試目的提供了解決方法。雖然對此功能的需求仍然是一個有效的請求,但必須考慮準備好的語句機制所施加的限制。
以上是如何檢索 PDO 準備語句執行的精確 SQL 查詢?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Laravel使用其直觀的閃存方法簡化了處理臨時會話數據。這非常適合在您的應用程序中顯示簡短的消息,警報或通知。 默認情況下,數據僅針對後續請求: $請求 -

PHP客戶端URL(curl)擴展是開發人員的強大工具,可以與遠程服務器和REST API無縫交互。通過利用Libcurl(備受尊敬的多協議文件傳輸庫),PHP curl促進了有效的執行

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显著减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

您是否想為客戶最緊迫的問題提供實時的即時解決方案? 實時聊天使您可以與客戶進行實時對話,並立即解決他們的問題。它允許您為您的自定義提供更快的服務

Laravel的服務容器和服務提供商是其架構的基礎。 本文探討了服務容器,詳細信息服務提供商創建,註冊,並通過示例演示了實際用法。 我們將從OVE開始

文章討論了PHP 5.3中介紹的PHP中的晚期靜態結合(LSB),允許靜態方法的運行時間分辨率調用以更靈活的繼承。 LSB的實用應用和潛在的觸摸

PHP日誌記錄對於監視和調試Web應用程序以及捕獲關鍵事件,錯誤和運行時行為至關重要。它為系統性能提供了寶貴的見解,有助於識別問題並支持更快的故障排除


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SublimeText3漢化版
中文版,非常好用

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3 Linux新版
SublimeText3 Linux最新版