JDBC 探索 SQLException 分析

JDBC 探索 SQLException 分析

1. SQLExceptionの概要

JDBC を使用してデータ ソース (この記事のデータ ソースは実際に使用するデータベースを表します) と対話するときにエラーが発生すると、SQLException という例外がスローされます。 SQLException には、エラーをより正確に特定するのに役立つ次の情報が含まれています。

エラーは次のことを示します:

取得するには getMessage メソッドを使用します。

SQL状態コード

コードは 5 つの文字と数字で構成されます。コードのほとんどは ISO/ANSI および Open Group (X/Open) によって標準化されていますが、データベース ベンダー自身によって実装されているコードもいくつかあります。

getSQLState メソッドを使用して取得します。

エラーコード

SQLState とは異なり、エラー コードはデータベース プロバイダーによって定義された整数値であり、実際のエラー コードが基になるデータ ソースによって返される可能性があります。

getErrorCode メソッドを使用して取得します。

原因

例外の原因を示します。getCause メソッドを継続的に呼び出すことで、例外の根本的な原因を取得できます。

例外チェーン

複数のエラーが発生した場合、例外はこのチェーンを通じて参照されます。

取得するには、getNextException メソッドを使用します。

2. SQLException の例

パブリック静的void printSQLException(SQLException e){
  for(Throwable e :ex){
    if (e インスタンスSQLException){
      (SQLException を無視します ((SQLException)e).getSQLState()) == false) {
        e.printStackTrace(System.err);
        System.err.println("SQLState: " + ((SQLException)e).getSQLState());
        System.err.println("エラーコード: " + ((SQLException)e).getErrorCode());
        System.err.println("メッセージ: " + e.getMessage());
        スロー可能 t = ex.getCause();
        while(t != null){
          System.out.println("原因: " + t);
          t = t.getCause();
        }
      }
    }
  }
}
パブリック静的ブール値 ignoreSQLException(String sqlState){
  if(sqlState == null){
    System.out.println("SQL 状態が定義されていません");
  }
  // X0Y32: Jar ファイルはスキーマ内に既に存在します
  if (sqlState.equalsIgnoreCase("X0Y32")) {
    true を返します。
  }
  // 42Y55: テーブルはスキーマ内に既に存在します
  if(sqlState.equalsIgnoreCase("42Y55")){
    true を返します。
  }
  true を返します。
}

注: 上記のコードは [http:docs.oracle.com] (http://docs.oracle.com/javase/tutorial/jdbc/basics/sqlexception.html) から取得したものです。

3. SQL警告

SQLWarning は SQLException の非常に重要なサブクラスであり、データベース アクセス中に発生する警告を示すために使用されます。例外として、SQLWarning はアプリケーションの実行を停止するのではなく、計画どおりに何も行われていないことをユーザーに警告します。たとえば、警告では、権限を取り消す試みが失敗したことや、切断を要求中にエラーが発生した可能性があることが通知される場合があります。

SQLWarning は、Connection、Statement (PreparedStatement および CallableStatement を含む)、または ResultSet によって報告されることがあります。これらのクラスにはすべて getWarnings メソッドがあります。このメソッドを呼び出すことによってのみ、呼び出しオブジェクトで報告された最初の警告を確認できます。 getWarning が警告を返す場合は、getNextWarning メソッドを呼び出して次の警告を取得できます。文の行が実行されるたびに、前の文の行の警告がクリアされます。つまり、レポート処理から警告を取得する場合は、次の文の行が実行される前に取得する必要があります。

DataTruncation は最も一般的な警告で、SQLState コード 01004 はデータの読み取りまたは書き込み時に問題が発生したことを示します。 DataTruncation には、どの列またはパラメータ データが切り捨てられるか、切り捨てが読み取り操作または書き込み操作のどちらで行われるか、転送されるバイト数、実際に転送されるバイト数などを理解するのに役立つ多くのメソッドがあります。

4. その他の種類のSQLException

BatchUpdateException: バッチ更新操作中にエラーが発生するとスローされます。提供されたメッセージに加えて、エラーが発生する前に強制終了されたすべてのステートメントが、提供された更新カウントで強制終了されます。

SQLClientInfoException: 接続時に 1 つ以上のクライアント情報プロパティを設定できない場合にスローされます。提供される情報に加えて、設定されていないクライアント情報プロパティのリストも提供されます。

すぐ...

要約する

以上が、JDBC 探索における SQLException 解析に関するこの記事の内容のすべてです。お役に立てれば幸いです。興味のある方は、引き続きこのサイトを参照してください: 共通 JDBC インターフェースの概要、JDBC を使用してデータ アクセス オブジェクト レイヤー (DAO) を実装するコード例など。ご質問がある場合は、いつでもメッセージを残すことができます。編集者が適時に返信します。どなたでも、ディスカッションのためにメッセージを残していただけます。

以下もご興味があるかもしれません:
  • SQL Server の System.OutOfMemoryException の解決方法
  • System.Data.SqlClient.SqlException: ログインによって要求されたデータベースを開くことができません。ログインに失敗しました。
  • java.sql.SQLException: 内部エラー: 指定された入力から Datum を構築できません

<<:  純粋なJSを使用してセカンダリメニュー効果を実現します

>>:  VMware12.0 インストール Ubuntu14.04 LTS チュートリアル

推薦する

製品の拡大鏡効果を実現する JavaScript

この記事では、参考までに、製品拡大鏡を実装するためのJavaScriptの具体的なコードを紹介します...

MySQL 5.7.31 64 ビット無料インストール版チュートリアル図

1. ダウンロードダウンロードアドレス: https://dev.mysql.com/get/Dow...

CSSを使用してHTMLテキストボックス内のテキストの垂直方向の中央を制御する

Text の height 属性が定義されている場合、Text に入力されたテキストは垂直方向に中央...

LambdaProbe を使用して Tomcat を監視する方法

導入: Lambda Probe (旧称 Tomcat Probe) は、Apache Tomcat...

docker を使用して複数のネットワーク インターフェースを持つコンテナーを起動する方法の例

コンテナにネットワークインターフェースを追加する1 デフォルトのネットワークモードでコンテナを実行す...

MySQL の連結で複数の一重引用符と三重引用符を使用する際の問題

文字列を動的に連結する場合、文字連結を使用することが多いです。次のような連結の引用符の意味がわかりま...

MySQL の全体的なアーキテクチャの紹介

MySQL の全体的なアーキテクチャは、サーバー層とストレージ エンジン層に分かれています。サーバー...

HTML で 2 列レイアウトを実装する方法の例 (左側は固定幅、右側は適応幅)

HTMLは2列レイアウトを実装し、左側は固定幅、右側は適応幅です。実装1: <スタイル>...

ウェブサイトのフッター沈下現象に対する3つの解決策を詳しく解説

背景多くのウェブサイトのデザインは、一般的にコンテンツ+フッターの2つの部分で構成されています。コン...

Webスキル: 複数のIEバージョンの共存ソリューション IETester

私のおすすめ複数のIEバージョンの共存のためのソリューション以前に IE6、IE7、IE8 の共存に...

Linux での Python スクリプトの自動起動とスケジュール起動の詳細な手順

1. Pythonは起動時に自動的に実行されますPython の自己起動スクリプトがauto.pyで...

mysql 8.0.19 win10 クイックインストールチュートリアル

このチュートリアルでは、参考までにMySQL 8.0.19のインストールチュートリアルを共有します。...

Docker Compose の実践とまとめ

Docker Compose は、Docker コンテナ クラスターのオーケストレーションを実現しま...

MySQLトランザクションを実行するための構文とプロセスの詳細な説明

概要: MySQL は、トランザクションをサポートするためにさまざまなストレージ エンジンを提供しま...