首頁 > 後端開發 > Golang > 如何識別 Postgres 驅動程式的「資料庫不存在」錯誤?

如何識別 Postgres 驅動程式的「資料庫不存在」錯誤?

Patricia Arquette
發布: 2024-11-02 17:03:29
原創
1117 人瀏覽過

How to Identify

確定db.Exec(...) 傳回的錯誤代碼

在使用Postgres 刪除資料庫的過程中驅動程式(lib/ pq),嘗試區分普通錯誤和「資料庫不存在」錯誤。為了實現這一點,就產生了以下問題:

是否有一個常數變數或機制可以用來識別傳回的錯誤是否表示資料庫不存在,或者是否需要手動解析錯誤字串?

雖然Postgres 文件沒有具體提及「資料庫不存在」錯誤代碼,但lib/pq 套件返回*pq.Error 類型的錯誤,這是一個包含各種字段的結構,提供詳細的錯誤信息。

要檢查錯誤代碼並執行所需的條件操作,請按以下步驟操作:

<code class="go">if err, ok := err.(*pq.Error); ok {
  // Here err is of type *pq.Error, you may inspect all its fields, e.g.:
  fmt.Println("pq error:", err.Code.Name())
}</code>
登入後複製

*pq.Error 結構包含以下字段,每個字段都包含Postres 特定的資訊和值:

<code class="go">type Error struct {
    Severity         string
    Code             ErrorCode
    Message          string
    Detail           string
    Hint             string
    Position         string
    InternalPosition string
    InternalQuery    string
    Where            string
    Schema           string
    Table            string
    Column           string
    DataTypeName     string
    Constraint       string
    File             string
    Line             string
    Routine          string
}</code>
登入後複製

這些欄位的含義和可能值的完整清單可以在Postgres 文件中找到:錯誤和通知訊息欄位。

透過利用這些字段,可以精確識別並在使用 Postgres 驅動程式進行資料庫操作時處理所需的錯誤情況。

以上是如何識別 Postgres 驅動程式的「資料庫不存在」錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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