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

数据库连接池的实现方式

转贴

?

?

?

?

查看文章
? ?

连接数据库的两种方式:

在Java应用程序中,数据库的连接一般有两种方式来得到。一种是通过java.sql.DriverManager的方式来得到数据库连接。这种方式不依赖于应用服务的支持,但是也不提供数据库连接池的功能。另外一种方式是通过javax.sql.DataSource的方式来得到数据库连接。在传统基于J2EE的应用需要通过JNDI来得到数据源(javax.sql.DataSource)对象,然后再通过数据源来得到相应的数据库连接。常见的应用服务器都支持这种方式,且一般都提供了数据库连接池的支持。如果不打算用应用服务器来管理你的数据库连接池,可以使用第三方的连接池管理工具如C3p0

一)jdbc直接连接,如下所示:???

??? Class.forName("com.ibm.db2.jcc.DB2Driver").newInstance();
??? String user = "db2admin";
??? String password = "db2kingdom";
??? String url = "jdbc:db2://192.168.47.1:50000/TESTDB2";
??? conn = DriverManager.getConnection(url,user,password);
???
??? return conn;

二)使用数据源

?? DataSource ds = null;
?? try {
??? Context ctx = new javax.naming.InitialContext();
??? ds = (javax.sql.DataSource) (DataSource) ctx.lookup("jdbc/ccsb");

?? } catch (NamingException e) {
??? System.out.println("===初始化数据源失败!指定的JNDI不存在:jdbc/ccsb);
?? } catch (Exception e) {
??? e.printStackTrace();
?? }
?? return ds;

数据源的管理

一) 交由应用服务器来管理,然后在应用服务器的JNDI对象中通过lookup()方法来查找取得数据源.

在tomcat中配置server.xml文件:


??????? auth="Container"
??????? type="javax.sql.DataSource"
??????? driverClassName="oracle.jdbc.driver.OracleDriver"
??????? url="jdbc:oracle:thin:@192.168.0.8:1521:ora9i"
??????? username="ccsb"
??????? password="ccsb"
??????? maxActive="20"
??????? maxIdle="10"
??????? maxWait="-1"/>

通过在中注册一个资源Resource,这时,该数据源就已经交由应用服务器来管理了.该应用启动的时候,该资源就会被实例话并在应用服务器JNDI对象中保存该实例的一个句柄“jdbc/ccsb”,当要使用该数据源的时候,可以通过lookup这个句柄来取得该对象,并将其强制转型.

二) 交由第三方的数据源管理组件

如C3p0组件等,此时无法通过索引应用服务器的JNDI树来获得该数据源,因为JNDI是应用服务器相关的.

数据库连接池

当使用数据源来操作数据库时,可以配置使用数据库连接池,来提高访问数据库的效率,对于连接池的管理也分为两种:1)应用服务器管理?? 2)第三方数据源管理组件来管理