JDBC-データベース接続

適切なドライバをインストールしたら、JDBCを使用してデータベース接続を確立します。

JDBC接続を確立するためのプログラミングは非常に簡単です。これらの簡単な4つのステップは次のとおりです-

  • Import JDBC Packages: 追加 import Javaコードに必要なクラスをインポートするためのJavaプログラムへのステートメント。

  • Register JDBC Driver: この手順により、JVMは目的のドライバー実装をメモリーにロードして、JVM要求を満たすことができるようにします。

  • Database URL Formulation: これは、接続先のデータベースを指す適切にフォーマットされたアドレスを作成するためです。

  • Create Connection Object:最後に、DriverManagerオブジェクトのgetConnection()メソッドへの呼び出しをコーディングして、実際のデータベース接続を確立します。

JDBCパッケージのインポート

ザ・ Import ステートメントは、Javaコンパイラに、コード内で参照するクラスの場所を示し、ソースコードの最初に配置されます。

SQLテーブルのデータを選択、挿入、更新、および削除できる標準のJDBCパッケージを使用するには、次のインポートをソースコードに追加します。

import java.sql.* ;  // for standard JDBC programs
import java.math.* ; // for BigDecimal and BigInteger support

JDBCドライバーの登録

ドライバーを使用する前に、プログラムにドライバーを登録する必要があります。ドライバの登録は、Oracleドライバのクラスファイルがメモリにロードされるプロセスであるため、JDBCインターフェイスの実装として利用できます。

この登録は、プログラムで1回だけ行う必要があります。ドライバーは2つの方法のいずれかで登録できます。

アプローチI-Class.forName()

ドライバーを登録するための最も一般的なアプローチは、Javaを使用することです。 Class.forName()メソッド。ドライバのクラスファイルをメモリに動的にロードし、メモリに自動的に登録します。この方法は、ドライバー登録を構成可能で移植可能にすることができるため、推奨されます。

次の例では、Class.forName()を使用してOracleドライバを登録します-

try {
   Class.forName("oracle.jdbc.driver.OracleDriver");
}
catch(ClassNotFoundException ex) {
   System.out.println("Error: unable to load driver class!");
   System.exit(1);
}

使用できます getInstance() 非準拠のJVMを回避する方法ですが、次のように2つの追加の例外をコーディングする必要があります-

try {
   Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
}
catch(ClassNotFoundException ex) {
   System.out.println("Error: unable to load driver class!");
   System.exit(1);
catch(IllegalAccessException ex) {
   System.out.println("Error: access problem while loading!");
   System.exit(2);
catch(InstantiationException ex) {
   System.out.println("Error: unable to instantiate driver!");
   System.exit(3);
}

アプローチII-DriverManager.registerDriver()

ドライバーの登録に使用できる2番目のアプローチは、静的を使用することです。 DriverManager.registerDriver() 方法。

Microsoftが提供するようなJDKに準拠していないJVMを使用している場合は、registerDriver()メソッドを使用する必要があります。

次の例では、registerDriver()を使用してOracleドライバを登録します-

try {
   Driver myDriver = new oracle.jdbc.driver.OracleDriver();
   DriverManager.registerDriver( myDriver );
}
catch(ClassNotFoundException ex) {
   System.out.println("Error: unable to load driver class!");
   System.exit(1);
}

データベースURLの定式化

ドライバをロードした後、を使用して接続を確立できます。 DriverManager.getConnection()方法。簡単に参照できるように、オーバーロードされた3つのDriverManager.getConnection()メソッドをリストします。

  • getConnection(String url)

  • getConnection(String url、Properties prop)

  • getConnection(String url、String user、String password)

ここでは、各フォームにデータベースが必要です URL。データベースURLは、データベースを指すアドレスです。

データベースURLの作成は、接続の確立に関連する問題のほとんどが発生する場所です。

次の表に、一般的なJDBCドライバー名とデータベースURLを示します。

RDBMS JDBCドライバー名 URL形式
MySQL com.mysql.jdbc.Driver jdbc:mysql://ホスト名/データベース名
オラクル oracle.jdbc.driver.OracleDriver jdbc:oracle:thin:@ホスト名:ポート番号:databaseName
DB2 COM.ibm.db2.jdbc.net.DB2Driver jdbc:db2:ホスト名:ポート番号/データベース名
Sybase com.sybase.jdbc.SybDriver jdbc:sybase:Tds:ホスト名:ポート番号/ databaseName

URL形式で強調表示されている部分はすべて静的であり、データベースの設定に従って残りの部分のみを変更する必要があります。

接続オブジェクトの作成

私たちは3つの形式をリストアップしました DriverManager.getConnection() 接続オブジェクトを作成するメソッド。

ユーザー名とパスワードでデータベースURLを使用する

getConnection()の最も一般的に使用される形式では、データベースURL、ユーザー名、およびパスワードを渡す必要があります

Oracleを使用していると仮定します thin ドライバの場合、URLのデータベース部分にhost:port:databaseName値を指定します。

TCP / IPアドレス192.0.0.1にホスト名amroodのホストがあり、Oracleリスナーがポート1521でリッスンするように構成されていて、データベース名がEMPの場合、完全なデータベースURLは次のようになります。

jdbc:oracle:thin:@amrood:1521:EMP

次に、適切なユーザー名とパスワードを使用してgetConnection()メソッドを呼び出して、を取得する必要があります。 Connection 次のようなオブジェクト-

String URL = "jdbc:oracle:thin:@amrood:1521:EMP";
String USER = "username";
String PASS = "password"
Connection conn = DriverManager.getConnection(URL, USER, PASS);

データベースURLのみを使用する

DriverManager.getConnection()メソッドの2番目の形式は、データベースURLのみを必要とします-

DriverManager.getConnection(String url);

ただし、この場合、データベースのURLにはユーザー名とパスワードが含まれ、次の一般的な形式になります。

jdbc:oracle:driver:username/password@database

したがって、上記の接続は次のように作成できます-

String URL = "jdbc:oracle:thin:username/password@amrood:1521:EMP";
Connection conn = DriverManager.getConnection(URL);

データベースURLとプロパティオブジェクトの使用

DriverManager.getConnection()メソッドの3番目の形式には、データベースURLとPropertiesオブジェクトが必要です-

DriverManager.getConnection(String url, Properties info);

Propertiesオブジェクトは、キーワードと値のペアのセットを保持します。これは、getConnection()メソッドの呼び出し中にドライバープロパティをドライバーに渡すために使用されます。

前の例と同じ接続を確立するには、次のコードを使用します-

import java.util.*;

String URL = "jdbc:oracle:thin:@amrood:1521:EMP";
Properties info = new Properties( );
info.put( "user", "username" );
info.put( "password", "password" );

Connection conn = DriverManager.getConnection(URL, info);

JDBC接続を閉じる

JDBCプログラムの最後に、データベースへのすべての接続を明示的に閉じて、各データベースセッションを終了する必要があります。ただし、忘れた場合、Javaのガベージコレクターは、古いオブジェクトをクリーンアップするときに接続を閉じます。

特にデータベースプログラミングでガベージコレクションに依存することは、プログラミング手法としては非常に貧弱です。接続オブジェクトに関連付けられたclose()メソッドを使用して、常に接続を閉じる習慣を付ける必要があります。

接続が確実に閉じられるようにするには、コードに「finally」ブロックを指定できます。A最後にかかわらず、例外発生した場合やないの、常に実行をブロックします。

上記で開いた接続を閉じるには、次のようにclose()メソッドを呼び出す必要があります-

conn.close();

接続を明示的に閉じると、DBMSリソースが節約され、データベース管理者が満足できるようになります。

理解を深めるために、JDBC-サンプルコードチュートリアルを学習することをお勧めします。