J2EE應用中與Oracle數據庫的連接
|
在J2EE應用程序開發中,應用程序與數據庫連接的建立是我們經常遇到的問題之一。在這里我主要談談在本地應用程序中通過OCI方式、thin方式和JdbcOdbc橋方式連接Oracle數據庫,在iPlanet Application Server 6.5和Sun ONE Application Server 7中對Oracle數據庫連接池的配置以及應用中如何從連接池中獲得連接。
一、本地通過JDBC獲得Oracle數據庫連接
通過JDBC獲得Oracle數據庫連接,有三種方式:OCI方式、thin方式和JdbcOdbc橋方式。OCI方式依賴于本地的動態鏈接庫,如果在本地安裝了Oracle數據庫客戶端可以采用該方式;而thin方式為純java的數據庫連接方式;JdbcOdbc橋方式依賴于本地ODBC數據庫源的配置,這種方式一般不太被采用。
1、OCI方式
先在本地安裝Oracle客戶端,安裝完之后,在安裝的路徑中可以找到…/jdbc/lib/classes12.zip文件,我們在環境變量classpath中設置classes12.zip所在的路徑。
然后通過以下的數據庫連接類,在本地通過OCI方式獲得Oracle數據庫連接。
| /** * 在本地獲得數據庫連接 */ package com.j2ee.db; import java.util.*; import java.sql.*; import javax.sql.*; import java.io.*; import oracle.jdbc.driver.*; import javax.naming.*; /** * 通過OCI方式獲得Oracle數據庫連接 */ public class DbConnection { final static String sDBDriver = "oracle.jdbc.driver.OracleDriver"; final static String sConnStr = "jdbc:oracle:oci8:sr/sr@ora199"; /** * */ public DbConnection() { } /** * 獲得Oracle數據庫連接 */ public java.sql.Connection connectDbByOci() { java.sql.Connection conn=null; try { Class.forName(sDBDriver); conn = DriverManager.getConnection(sConnStr); } catch (Exception e) { System.out.println("ERROR:"+e.getMessage()); } return conn; } } |
在連接字符串 "jdbc:oracle:oci8:sr/sr@ora199" 中,"sr/sr"為Oracle用戶的用戶名和口令,"ora199"為數據庫服務名。