1.传统链接(如下为示意图)
注意:
(1).传统方式找drivermanager要连接,数目是有限的。
(2).传统方式的close(),并没有将connection重用,只是切断应用程序和数据库的桥梁,即无发送到sql命令到数据库端执行
(3).项目中,对于connection不说,不会直接使用drivermanager取得,而使用连接池方式。
2.采用连接池(示意图)
3.开源数据库连接池
(1).现在很多web服务器(weblogic, websphere, tomcat)都提供了datasoruce的实现,即连接池的实现。通常我们把datasource的实现,按其英文含义称之为数据源,数据源中都包含了数据库连接池的实现。
(2).也有一些开源组织提供了数据源的独立实现:
dbcp 数据库连接池(tomcat)
c3p0 数据库连接池(hibernate)
(3).实际应用时不需要编写连接数据库代码,直接从数据源获得数据库的连接。程序员编程时也应尽量使用这些数据源的实现,以提升程序的数据库访问性能。
4.c3p0的使用:
(1).在classpath的路径下配置xml文件,即src的文件下而且这个文件名必须是c3p0-config.xml
原始的c3p0-config.xml的文件参数:
3 30 1000 false test false 100 null false 60 3 60 15 100 3 root password select id from test where id=1 300 false true root false con_test 30000 30 10 30 25 10 0 200 300
实战练习:
1>.首先配置c3p0-config.xml文件 com.mysql.jdbc.driver root wwh jdbc:mysql://127.0.0.1:3306/jdbctest
2>.代码操作连接(testc3p0.java)package cn.wwh.www.java.jdbc.datasource;import java.sql.connection;import com.mchange.v2.c3p0.combopooleddatasource;/** *类的作用: * * *@author 一叶扁舟 *@version 1.0 *@创建时间: 2014-9-2 上午12:02:13 *///测试连接池c3p0的用法public class testc3p0 { public static void main(string[] args) throws exception { long begin = system.currenttimemillis(); //创建c3p0连接池,并加载c3p0-config.xml文件 combopooleddatasource datasource = new combopooleddatasource(); for(int i=1;idbcp连接池需要dbcp.properties文件,同时需加入3个对应的jar包
3>c3p0连接池需要在/web-inf/classes/目录下存放c3p0-config.xml文件,该类combopooleddatasource在创建时
会自动在指定的目录下找xml文件,并加载默认设置
4>tomcat用的也是c3p0
6.导入的jar包
commons-dbcp.jar:dbcp实现要导入的jar
commons-pool.jar: 连接池实现的依赖类
commons-collections.jar :连接池实现的集合类
c3p0-0.9.1.2.jar :c3p0实现要导入的jar包