日期:2014-05-16  浏览次数:20388 次

使用Java连接池连接Oracle数据库
1.Java程序连接数据库的四种方法
1  JDBC-ODBC桥和ODBC驱动程序--在这种方式下,这是一个本地解决方案,因为ODBC驱动程序和桥代码必须出现在用户的每台机器中。从根本上说这是一个临时解决方案。
2  本机代码和Java驱动程序--它用另一个本地解决方案(该平台上的Java可调用的本机代码)取代 ODBC 和 JDBC-ODBC 桥。
3  JDBC网络的纯Java驱动程序--由Java驱动程序翻译的JDBC形成传送给服务器的独立协议。然后,服务器可连接任何数量的数据库。这种方法使您可能从客户机Applet中调用服务器,并将结果返回到您的Applet。在这种情况下,中间件软件提供商可提供服务器。
4  本机协议Java驱动程序-- Java驱动程序直接转换为该数据库的协议并进行调用。这种方法也可以通过网络使用,而且可以在Web浏览器的Applet中显示结果。在这种情况下,每个数据库厂商将提供驱动程序。


2.使用连接池和语句池 提高 Oracle 驱动的 JDBC 程序的性能
    使用诸如连接池和语句池等池技术可以显著提高数据库密集型应用程序的性能,因为这样可以实现对象重用,而无需花费时间和资源重新创建对象。
如果应用程序与数据库频繁交互并且经常使用相同的参数重新建立连接,那么重用表示应用程序使    用的物理数据库连接的数据库连接对象可显著提高性能。反之,如果应用程序与其基础数据库很少连接,您不会因使用连接池获益。实际上,如果池的设置(例如,允许的最大或最小连接数限制)针对特定应用程序进行了优化,许多数据库密集型应用程序都可以因使用连接池获益。
    与连接池一样,语句池也是用于提高应用程序性能的技术。通过在应用程序运行期间多次执行语句池,可以进一步提高性能。然而,我们应该意识到语句池并不是解决性能问题的灵丹妙药。如果对每条语句进行缓存而不辨别其在程序中执行的次数,则不可能获得任何性能改进。实际上,由于将语句放入缓存并保存在缓存中将产生开销,因此对在程序执行期间仅执行一次的语句进行缓存将降低性能。



3.准备好驱动和连接池
准备数据库驱动:
由于安装的数据库是oracle10g个人版,这里下载的是oracle10g瘦版JDBC(相当于前面Java数据库连接方式的第四种)地址是:
http://www.oracle.com/technology/software/tech/java/sqlj_jdbc/htdocs/jdbc_10201.html

准备数据库连接池
DBCP是apache的数据库连接池项目,其依赖于commons-pool 下载地址是:
http://commons.apache.org/dbcp/download_dbcp.cgi
http://commons.apache.org/pool/downloads.html



4.初始化连接代码


Java代码

   1. import org.apache.commons.dbcp.BasicDataSource; 
   2. import java.sql.SQLException; 
   3. import java.sql.Connection; 
   4. /**
   5.  * 使用DBCP 1.4 做数据库连接池 DBCP1.4支持JDK1.6
   6. */ 
   7. public class Dbcp extends DBConnection 
   8. { 
   9.     private BasicDataSource dataSource = null; 
  10.   
  11.     // 初始化数据连接 
  12.   public void initDataSource() 
  13.    { 
  14.          if (dataSource != null) 
  15.         { 
  16.              try 
  17.             { 
  18.                 dataSource.close(); 
  19.             } 
  20.             catch (Exception e) 
  21.            { 
  22.                e.printStackTrace(); 
  23.            } 
  24.            dataSource = null; 
  25.        } 
  26.  
  27.        try 
  28.       {      
  29.           dataSource = new BasicDataSource(); 
  30.          dataSource.setDriverClassName("oracle.jdbc.driver.OracleDriver"); 
  31.          dataSource.setUrl("jdbc:oracle:thin:@127.0.0.1:1521:XE"); 
  32.