位置:首頁 > Java技術 > JDBC教學 > JDBC連接數據庫

JDBC連接數據庫

在安裝相應的驅動程序後,現在是時候建立使用JDBC的數據庫連接。

涉及到建立一個JDBC連接的編程是相當簡單的。下麵是這些簡單的四個步驟:

  • 導入JDBC包: 添加import語句到Java程序導入所需的類在Java代碼中。

  • 注冊JDBC驅動程序:這一步會導致JVM加載所需的驅動程序實現到內存中,因此它可以實現JDBC請求。

  • 數據庫URL製定:這是創建格式正確的地址指向到要連接的數據庫。

  • 創建連接對象:最後,代碼調用DriverManager對象的getConnection()方法來建立實際的數據庫連接。

導入JDBC包:

import 語句告訴Java編譯器在哪裡可以找到在代碼中引用,並放置在您的源代碼最開始的類。

使用標準的JDBC包,它允許選擇,插入,更新和SQL表中刪除數據,添加以下進口到您的源代碼:

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

注冊JDBC驅動程序:

使用它之前,必須注冊你的驅動程序在程序。注冊驅動程序是由Oracle驅動程序的類文件被加載到內存中以便它可以被用作JDBC接口的實現過程。

需要做這個注冊隻能在你的程序一次。可以通過以下兩種方式之一注冊一個驅動程序。

方法(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,但要編寫了兩個額外的例外情況如下:

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);
}

方法(二) - DriverManager.registerDriver():

可以用它來注冊一個驅動程序的第二種方法是使用staticDriverManager.registerDriver()方法。

應該,如果使用的是不兼容的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()方法的連接。為方便參考,讓列出了三個重載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://hostname/ databaseName
ORACLE oracle.jdbc.driver.OracleDriver jdbc:oracle:thin:@hostname:port Number:databaseName
DB2 COM.ibm.db2.jdbc.net.DB2Driver jdbc:db2:hostname:port Number/databaseName
Sybase com.sybase.jdbc.SybDriver jdbc:sybase:Tds:hostname: port Number/databaseName

以URL格式所有高亮的部分是靜態的,需要改變隻剩餘部分按照數據庫設置。

創建連接對象:

使用數據庫URL的用戶名和密碼:

下麵三種形式DriverManager.getConnection()方法來創建一個連接對象。getConnection()最常用形式要求傳遞一個數據庫URL,用戶名 username和密碼 password: 

對URL數據庫部分databaseName的值:假設使用的是Oracle的瘦驅動程序,需要指定一個主機:端口。

假設有一台主機TCP/IP地址192.0.0.1 以及主機名和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()方法隻需要一個數據庫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和一個Properties對象:

第三種形式DriverManager.getConnection()方法需要一個數據庫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塊執行。 finally塊都會執行,不管是否發生或也不例外。

要關閉上麵打開的連接,應該調用close()方法,如下所示:

conn.close();

顯式地關閉連接DBMS節約資源。

為了更好地理解,建議看看JDBC - 示例代碼