java数据库连接池代码实现

来源:互联网 发布:ctrl alt 互换 linux 编辑:程序博客网 时间:2024/06/15 00:52

连接池原理已经解释了,下面该看看代码是如何实现的吧

    数据库连接池有很多,我就不一一列举了,有 dbcp,c3p0, Proxool,BoneCP,Druid............强迫症可以自己去百度,然后背下来

简单介绍一下,

DBCP(DataBase connection pool),数据库连接池。是 apache 上的一个 java 连接池项目,也是 tomcat 使用的连接池组件。单独使用dbcp需要2个包:commons-dbcp.jar,commons-pool.jar

C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。目前使用它的开源项目有Hibernate,Spring等。mysql-connector-java-5.0.8-bin.jar,mchange-commons-0.2.jar,c3p0-0.9.2-pre1.jar(版本自己自由发挥)

Proxool是一种Java数据库连接池技术。sourceforge下的一个开源项目,这个项目提供一个健壮、易用的连接池,最为关键的是这个连接池提供监控的功能,方便易用,便于发现连接泄漏的情况 。commons-logging.jar,proxool-0.9.0RC2.jar

  好,常见的就以上三种,其它就不介绍了,可以自己百度


最精彩的代码片段来了

import java.io.InputStream;import java.sql.Connection;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import java.util.Properties;import javax.sql.DataSource;import org.apache.commons.dbcp.BasicDataSourceFactory;public class JdbcUtilDBCP {private static DataSource datasource = null;static{try{//读取资源文件中的信息InputStream in = JdbcUtilDBCP.class.getClassLoader().getResourceAsStream("dbcpconfig.properties");Properties config = new Properties();config.load(in);BasicDataSourceFactory factory = new BasicDataSourceFactory();datasource = factory.createDataSource(config);}catch (Exception e) {throw new ExceptionInInitializerError(e);}}public static Connection getConnection() throws SQLException{return datasource.getConnection();}public static void release(Connection conn, Statement st, ResultSet rs){if (rs != null){try{rs.close();}catch (Exception e) {e.printStackTrace();}rs = null;}if (st != null){try{st.close();}catch (Exception e) {e.printStackTrace();}st = null;}if (conn != null){try {conn.close();} catch (Exception e) {e.printStackTrace();}}}}#连接设置driverClassName=com.mysql.jdbc.Driverurl=jdbc:mysql://localhost:3306/test1username=rootpassword=123456#initialSize=10#最大连接数量maxActive=50#maxIdle=20#minIdle=5#maxWait=60000#JDBC驱动建立连接时附带的连接属性属性的格式必须为这样:[属性名=property;] #注意:"user" 与 "password" 两个属性会被明确地传递,因此这里不需要包含他们。connectionProperties=useUnicode=true;characterEncoding=utf8#指定由连接池所创建的连接的自动提交(auto-commit)状态。defaultAutoCommit=true#driver default 指定由连接池所创建的连接的只读(read-only)状态。#如果没有设置该值,则“setReadOnly”方法将不被调用。(某些驱动并不支持只读模式,如:Informix)defaultReadOnly=#driver default 指定由连接池所创建的连接的事务级别(TransactionIsolation)。#可用值为下列之一:(详情可见javadoc。)NONE,READ_UNCOMMITTED, READ_COMMITTED, REPEATABLE_READ, SERIALIZABLEdefaultTransactionIsolation=READ_COMMITTED

import java.sql.Connection;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import com.mchange.v2.c3p0.ComboPooledDataSource;public class JdbcUtilC3P0 {private static ComboPooledDataSource ds = null;static{try{ds = new ComboPooledDataSource();}catch (Exception e) {throw new ExceptionInInitializerError(e);}}public static Connection getConnection() throws SQLException{return ds.getConnection();}public static void release(Connection conn,Statement st,ResultSet rs){if(rs!=null){try{rs.close();   //throw new }catch (Exception e) {e.printStackTrace();}rs = null;}if(st!=null){try{st.close();}catch (Exception e) {e.printStackTrace();}st = null;}if(conn!=null){try{conn.close();}catch (Exception e) {e.printStackTrace();}}}}com.mysql.jdbc.Driverjdbc:mysql://localhost:3306/userrootroot10302052005010050100005
com.mysql.jdbc.Driverjdbc:mysql://localhost:3306/userrootroot10302052005010050100005






原创粉丝点击