ホームページ バックエンド開発 Golang Postgres ドライバーを使用して、一般的なエラーと「データベースが存在しません」エラーなどの特定の状況を区別するにはどうすればよいですか?

Postgres ドライバーを使用して、一般的なエラーと「データベースが存在しません」エラーなどの特定の状況を区別するにはどうすればよいですか?

Nov 03, 2024 am 02:50 AM

How can I differentiate between generic errors and specific conditions like

データベース操作からのエラー コードの取得

Postgres ドライバー (lib/pq) を使用してクエリを実行する場合、場合によっては次のエラー コードを区別する必要があります。一般的なエラーと、「データベースが存在しない」エラーなどの特定の条件です。これを容易にするために、Postgres ドライバーはエラーの詳細を検査するための構造化されたアプローチを提供します。

エラー コードへのアクセス

db.Exec(...) によって返されるエラーは次のとおりです。 *pq.Error と入力します。これは、エラーを説明するさまざまなフィールドを含む構造体です。これらのフィールドにアクセスするには、次の構文を使用します。

if err, ok := err.(*pq.Error); ok {
    // Inspect error fields, such as:
    fmt.Println("Error code:", err.Code.Name())
}
ログイン後にコピー

「データベースが存在しない」エラーの特定

残念ながら、「データベース」専用のエラー コードはありません。存在しません」というエラーが発生します。代わりに、より一般的な「28003: データベースが存在しません」エラーに分類されます。この状態を確認するには、次のコードを使用します。

if err, ok := err.(*pq.Error); ok {
    if err.Code.Name() == "28003" {
        // Database does not exist
    }
}
ログイン後にコピー

追加フィールド

エラー コードに加えて、*pq.Error 構造体は他の便利なフィールドを提供します。以下を含むフィールド:

  • メッセージ: 人間が判読できるエラー メッセージ。
  • 重大度: エラーの重大度。 "NOTICE" から "FATAL" まで。
  • 詳細: エラーに関する追加の詳細。
  • ヒント: エラーを解決する方法に関する提案.
  • 位置: エラーが発生した SQL ステートメント内の位置。

これらのフィールドを利用することで、開発者は実行中に発生したエラーをより深く理解できます。データベース操作により、より多くの情報に基づいたエラー処理とデバッグが可能になります。

以上がPostgres ドライバーを使用して、一般的なエラーと「データベースが存在しません」エラーなどの特定の状況を区別するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか? Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか? Mar 03, 2025 pm 05:17 PM

Go Language Packのインポート:アンダースコアとアンダースコアなしの違いは何ですか?

Beegoフレームワークのページ間で短期情報転送を実装する方法は? Beegoフレームワークのページ間で短期情報転送を実装する方法は? Mar 03, 2025 pm 05:22 PM

Beegoフレームワークのページ間で短期情報転送を実装する方法は?

GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか? GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか? Mar 10, 2025 pm 05:38 PM

GOでテスト用のモックオブジェクトとスタブを書くにはどうすればよいですか?

トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか? トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか? Mar 10, 2025 pm 05:36 PM

トレースツールを使用して、GOアプリケーションの実行フローを理解するにはどうすればよいですか?

MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は? MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は? Mar 03, 2025 pm 05:18 PM

MySQLクエリ結果リストをGO言語のカスタム構造スライスに変換する方法は?

GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか? GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか? Mar 10, 2025 pm 03:20 PM

GOのジェネリックのカスタムタイプ制約を定義するにはどうすればよいですか?

Go言語でファイルを便利に書く方法は? Go言語でファイルを便利に書く方法は? Mar 03, 2025 pm 05:15 PM

Go言語でファイルを便利に書く方法は?

Linterと静的分析ツールを使用して、GOコードの品質と保守性を向上させるにはどうすればよいですか? Linterと静的分析ツールを使用して、GOコードの品質と保守性を向上させるにはどうすればよいですか? Mar 10, 2025 pm 05:38 PM

Linterと静的分析ツールを使用して、GOコードの品質と保守性を向上させるにはどうすればよいですか?

See all articles