首頁 > 後端開發 > Golang > 如何處理 Postgres 中 pq.Error 的「資料庫不存在」錯誤?

如何處理 Postgres 中 pq.Error 的「資料庫不存在」錯誤?

Linda Hamilton
發布: 2024-11-03 07:33:02
原創
558 人瀏覽過

How to Handle

db.Exec() 之後Postgres 中的錯誤代碼

使用db.Exec() 執行查詢時,傳回的錯誤可以提供有關操作狀態的有價值的資訊。雖然實際的錯誤訊息可能有所不同,但 Postgres 驅動程式提供了一種檢查特定條件下的錯誤代碼的方法。

存取錯誤代碼

從db.Exec() 傳回的錯誤,您可以將其斷言鍵入 *pq.Error 類型,然後使用其 Code 欄位。以下是一個範例:

<code class="go">if err, ok := err.(*pq.Error); ok {
    fmt.Println("Error code:", err.Code)
}</code>
登入後複製

「資料庫不存在」的錯誤代碼

不幸的是,Postgres 沒有提供「資料庫不存在」的具體錯誤代碼「錯誤。錯誤的程式碼欄位可能會設定為「42P01」(表示「語法錯誤」),但這並不能保證。

檢查特定錯誤代碼

由於「資料庫不存在」錯誤沒有特定的錯誤代碼,因此您需要自行手動解析錯誤訊息字串。欄位

<code class="go">if strings.Contains(err.Error(), "existence") && strings.Contains(err.Error(), "database") {
    // Database does not exist
}</code>
登入後複製

除了錯誤代碼之外,pq.Error 類型還提供其他欄位可以提供有價值的上下文,例如:

訊息:錯誤訊息字串

詳細資訊:有關錯誤的詳細資訊
  • 提示:有關如何進行操作的提示解決錯誤
  • 位置:輸入查詢中發生錯誤的位置
  • 位置:查詢中錯誤的來源

以上是如何處理 Postgres 中 pq.Error 的「資料庫不存在」錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板