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

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

Patricia Arquette
Patricia Arquetteオリジナル
2024-11-03 02:50:03429ブラウズ

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 までご連絡ください。