JDBC連接數(shù)據(jù)庫
涉及到建立一個(gè)JDBC連接的編程是相當(dāng)簡單的。下面是這些簡單的四個(gè)步驟:
導(dǎo)入JDBC包:
import 語句告訴Java編譯器在哪里可以找到在代碼中引用,并放置在您的源代碼最開始的類。
使用標(biāo)準(zhǔn)的JDBC包,它允許選擇,插入,更新和SQL表中刪除數(shù)據(jù),添加以下進(jìn)口到您的源代碼:
import java.sql.* ; // for standard JDBC programsimport java.math.* ; // for BigDecimal and BigInteger support
注冊JDBC驅(qū)動程序:
使用它之前,必須注冊你的驅(qū)動程序在程序。注冊驅(qū)動程序是由Oracle驅(qū)動程序的類文件被加載到內(nèi)存中以便它可以被用作JDBC接口的實(shí)現(xiàn)過程。
需要做這個(gè)注冊只能在你的程序一次??梢酝ㄟ^以下兩種方式之一注冊一個(gè)驅(qū)動程序。
方法(I)- Class.forName():
注冊一個(gè)驅(qū)動程序中最常用的方法是使用Java的Class.forName()方法來動態(tài)加載驅(qū)動程序的類文件到內(nèi)存中,它會自動將其注冊。這種方法是可取的,因?yàn)樗试S使驅(qū)動注冊配置,便于攜帶。
下面的示例使用Class.forName()來注冊O(shè)racle驅(qū)動程序:
try { Class.forName("oracle.jdbc.driver.OracleDriver");}catch(ClassNotFoundException ex) { System.out.println("Error: unable to load driver class!"); System.exit(1);}
可以使用getInstance()方法來解決不兼容的JVM,但要編寫了兩個(gè)額外的例外情況如下:
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():
可以用它來注冊一個(gè)驅(qū)動程序的第二種方法是使用staticDriverManager.registerDriver()方法。
應(yīng)該,如果使用的是不兼容的JDK JVM,比如微軟提供一個(gè)使用registerDriver()方法。
下面的示例使用registerDriver()來注冊O(shè)racle驅(qū)動程序:
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);}
數(shù)據(jù)庫URL制定:
當(dāng)加載的驅(qū)動程序,可以建立程序中使用DriverManager.getConnection()方法的連接。為方便參考,讓列出了三個(gè)重載DriverManager.getConnection()方法:
在這里,每個(gè)表單需要一個(gè)數(shù)據(jù)庫URL。數(shù)據(jù)庫的URL是指向數(shù)據(jù)庫地址。
制定一個(gè)數(shù)據(jù)庫URL是大多數(shù)用在建立連接相關(guān)。
下表列出了下來流行的JDBC驅(qū)動程序名和數(shù)據(jù)庫的URL。
RDBMS JDBC驅(qū)動程序的名稱 URL 格式
MySQL com.mysql.jdbc.Driver jdbc:mysql://hostname/ databaseNameORACLE oracle.jdbc.driver.OracleDriver jdbc:oracle:thin:@hostname:port Number:databaseNameDB2 COM.ibm.db2.jdbc.net.DB2Driver jdbc:db2:hostname:port Number/databaseNameSybase com.sybase.jdbc.SybDriver jdbc:sybase:Tds:hostname: port Number/databaseName
以URL格式所有高亮的部分是靜態(tài)的,需要改變只剩余部分按照數(shù)據(jù)庫設(shè)置。
創(chuàng)建連接對象: 使用數(shù)據(jù)庫URL的用戶名和密碼:
下面三種形式DriverManager.getConnection()方法來創(chuàng)建一個(gè)連接對象。getConnection()最常用形式要求傳遞一個(gè)數(shù)據(jù)庫URL,用戶名 username和密碼 password:
對URL數(shù)據(jù)庫部分databaseName的值:假設(shè)使用的是Oracle的瘦驅(qū)動程序,需要指定一個(gè)主機(jī):端口。
假設(shè)有一臺主機(jī)TCP/IP地址192.0.0.1 以及主機(jī)名和Oracle監(jiān)聽器被配置為在端口1521,數(shù)據(jù)庫名稱是EMP,然后完整的數(shù)據(jù)庫URL是:
jdbc:oracle:thin:@amrood:1521:EMP
現(xiàn)在,必須調(diào)用適當(dāng)?shù)挠脩裘兔艽a以及getConnection()方法來獲得一個(gè)Connection對象,如下所示:
String URL = "jdbc:oracle:thin:@amrood:1521:EMP";String USER = "username";String PASS = "password"Connection conn = DriverManager.getConnection(URL, USER, PASS);
只使用一個(gè)數(shù)據(jù)庫URL:
第二種形式 DriverManager.getConnection()方法只需要一個(gè)數(shù)據(jù)庫URL:
DriverManager.getConnection(String url);
然而,在這種情況下,數(shù)據(jù)庫的URL,包括用戶名和密碼,并具有以下的一般形式:
jdbc:oracle:driver:username/password@database
所以上面的連接可以創(chuàng)建如下:
String URL = "jdbc:oracle:thin:username/password@amrood:1521:EMP";Connection conn = DriverManager.getConnection(URL);
使用數(shù)據(jù)庫的URL和一個(gè)Properties對象:
第三種形式DriverManager.getConnection()方法需要一個(gè)數(shù)據(jù)庫URL和一個(gè)Properties對象:
DriverManager.getConnection(String url, Properties info);
Properties對象,保存一組關(guān)鍵字 - 值對。它被用來調(diào)用getConnection()方法時(shí)驅(qū)動程序?qū)傩詡鬟f給驅(qū)動程序。
為了使通過前面的例子中所做的相同的連接,使用下面的代碼:
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);
關(guān)閉JDBC連接:
在JDBC程序的結(jié)束,它明確要求關(guān)閉所有的連接到數(shù)據(jù)庫,以結(jié)束每個(gè)數(shù)據(jù)庫會話。但是,如果忘了,Java垃圾收集器會關(guān)閉連接時(shí),它會清除陳舊的對象。
依托垃圾收集,特別是在數(shù)據(jù)庫編程,是非常差的編程習(xí)慣。應(yīng)該總是在關(guān)閉與連接對象關(guān)聯(lián)的close()方法連接的習(xí)慣。
為了確保連接被關(guān)閉,可以在代碼中的finally塊執(zhí)行。 finally塊都會執(zhí)行,不管是否發(fā)生或也不例外。
要關(guān)閉上面打開的連接,應(yīng)該調(diào)用close()方法,如下所示:
conn.close();
顯式地關(guān)閉連接DBMS節(jié)約資源。
創(chuàng)建JDBC應(yīng)用程序:
有下列涉及構(gòu)建JDBC應(yīng)用程序的六個(gè)步驟:
示例代碼:
這個(gè)范例的例子可以作為一個(gè)模板,在需要建立JDBC應(yīng)用程序。
基于對環(huán)境和數(shù)據(jù)庫安裝在前面的章節(jié)中做此示例代碼已寫入。
復(fù)制下面的例子FirstExample.java,編譯并運(yùn)行,如下所示:
//STEP 1. Import required packagesimport java.sql.*;public class FirstExample { // JDBC driver name and database URL static final String JDBC_DRIVER = "com.mysql.jdbc.Driver"; static final String DB_URL = "jdbc:mysql://localhost/EMP"; // Database credentials static final String USER = "username"; static final String PASS = "password"; public static void main(String[] args) { Connection conn = null; Statement stmt = null; try{ //STEP 2: Register JDBC driver Class.forName("com.mysql.jdbc.Driver"); //STEP 3: Open a connection System.out.println("Connecting to database..."); conn = DriverManager.getConnection(DB_URL,USER,PASS); //STEP 4: Execute a query System.out.println("Creating statement..."); stmt = conn.createStatement(); String sql; sql = "SELECT id, first, last, age FROM Employees"; ResultSet rs = stmt.executeQuery(sql); //STEP 5: Extract data from result set while(rs.next()){ //Retrieve by column name int id = rs.getInt("id"); int age = rs.getInt("age"); String first = rs.getString("first"); String last = rs.getString("last"); //Display values System.out.print("ID: " + id); System.out.print(", Age: " + age); System.out.print(", First: " + first); System.out.println(", Last: " + last); } //STEP 6: Clean-up environment rs.close(); stmt.close(); conn.close(); }catch(SQLException se){ //Handle errors for JDBC se.printStackTrace(); }catch(Exception e){ //Handle errors for Class.forName e.printStackTrace(); }finally{ //finally block used to close resources try{ if(stmt!=null) stmt.close(); }catch(SQLException se2){ }// nothing we can do try{ if(conn!=null) conn.close(); }catch(SQLException se){ se.printStackTrace(); }//end finally try }//end try System.out.println("Goodbye!");}//end main}//end FirstExample
現(xiàn)在來編譯上面的例子如下:
C:>javac FirstExample.java
當(dāng)運(yùn)行FirstExample,它會產(chǎn)生以下結(jié)果:
C:>java FirstExample
Connecting to database...Creating statement...ID: 100, Age: 18, First: Zara, Last: AliID: 101, Age: 25, First: Mahnaz, Last: FatmaID: 102, Age: 30, First: Zaid, Last: KhanID: 103, Age: 28, First: Sumit, Last: Mittal
新聞熱點(diǎn)
疑難解答
圖片精選