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.