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