JDBC-はじめに

JDBCとは何ですか?

JDBCは Jエイバ Dアタbase Connectivityは、Javaプログラミング言語とさまざまなデータベース間のデータベースに依存しない接続のための標準JavaAPIです。

JDBCライブラリには、データベースの使用に一般的に関連付けられている、以下で説明する各タスクのAPIが含まれています。

  • データベースへの接続を確立します。

  • SQLまたはMySQLステートメントの作成。

  • データベースでSQLまたはMySQLクエリを実行します。

  • 結果のレコードの表示と変更。

基本的に、JDBCは、基盤となるデータベースへのポータブルアクセスを可能にするインターフェイスの完全なセットを提供する仕様です。Javaを使用して、次のようなさまざまなタイプの実行可能ファイルを作成できます。

  • Javaアプリケーション

  • Javaアプレット

  • Javaサーブレット

  • Java ServerPages(JSP)

  • エンタープライズJavaBeans(EJB)。

これらのさまざまな実行可能ファイルはすべて、JDBCドライバーを使用してデータベースにアクセスし、保存されたデータを利用できます。

JDBCはODBCと同じ機能を提供し、Javaプログラムにデータベースに依存しないコードを含めることができます。

前提条件

先に進む前に、次の2つの主題をよく理解する必要があります-

  • コアJAVAプログラミング

  • SQLまたはMySQLデータベース

JDBCアーキテクチャ

JDBC APIは、データベースアクセス用に2層と3層の両方の処理モデルをサポートしますが、一般に、JDBCアーキテクチャは2つの層で構成されています。

  • JDBC API: これにより、アプリケーションからJDBCManagerへの接続が提供されます。

  • JDBC Driver API: これは、JDBCマネージャーからドライバーへの接続をサポートします。

JDBC APIは、ドライバーマネージャーとデータベース固有のドライバーを使用して、異種データベースへの透過的な接続を提供します。

JDBCドライバーマネージャーは、各データソースへのアクセスに正しいドライバーが使用されていることを確認します。ドライバーマネージャーは、複数の異種データベースに接続された複数の同時ドライバーをサポートできます。

以下は、JDBCドライバーとJavaアプリケーションに関するドライバーマネージャーの場所を示すアーキテクチャ図です。

一般的なJDBCコンポーネント

JDBC APIは、次のインターフェイスとクラスを提供します-

  • DriverManager:このクラスは、データベースドライバーのリストを管理します。通信サブプロトコルを使用して、Javaアプリケーションからの接続要求を適切なデータベースドライバと照合します。JDBCの下で特定のサブプロトコルを認識する最初のドライバーは、データベース接続を確立するために使用されます。

  • Driver:このインターフェースは、データベースサーバーとの通信を処理します。Driverオブジェクトと直接対話することはめったにありません。代わりに、このタイプのオブジェクトを管理するDriverManagerオブジェクトを使用します。また、Driverオブジェクトの操作に関連する詳細を抽象化します。

  • Connection:データベースに接続するためのすべてのメソッドとのこのインターフェイス。接続オブジェクトは通信コンテキストを表します。つまり、データベースとのすべての通信は接続オブジェクトのみを介して行われます。

  • Statement:このインターフェイスから作成されたオブジェクトを使用して、SQLステートメントをデータベースに送信します。一部の派生インターフェイスは、ストアドプロシージャの実行に加えてパラメータを受け入れます。

  • ResultSet:これらのオブジェクトは、Statementオブジェクトを使用してSQLクエリを実行した後、データベースから取得したデータを保持します。これは、データ内を移動できるようにするイテレーターとして機能します。

  • SQLException: このクラスは、データベースアプリケーションで発生するエラーを処理します。

JDBC4.0パッケージ

java.sqlとjavax.sqlは、JDBC4.0のプライマリパッケージです。これは、このチュートリアルを書いている時点での最新のJDBCバージョンです。データソースと対話するためのメインクラスを提供します。

これらのパッケージの新機能には、次の領域での変更が含まれます-

  • データベースドライバの自動ロード。

  • 例外処理の改善。

  • 強化されたBLOB / CLOB機能。

  • 接続およびステートメントインターフェイスの機能強化。

  • 各国の文字セットのサポート。

  • SQLROWIDアクセス。

  • SQL 2003XMLデータ型のサポート。

  • Annotations.