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

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

Linda Hamilton
Linda Hamilton原創
2024-11-03 07:33:02588瀏覽

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中文網其他相關文章!

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