データベース操作からのエラー コードの取得
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 構造体は他の便利なフィールドを提供します。以下を含むフィールド:
これらのフィールドを利用することで、開発者は実行中に発生したエラーをより深く理解できます。データベース操作により、より多くの情報に基づいたエラー処理とデバッグが可能になります。
以上がPostgres ドライバーを使用して、一般的なエラーと「データベースが存在しません」エラーなどの特定の状況を区別するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。