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.Driver jdbc:mysql://localhost:3306/user root root 10 30 20 5 200 50 100 50 1000 0 5
com.mysql.jdbc.Driver jdbc:mysql://localhost:3306/user root root 10 30 20 5 200 50 100 50 1000 0 5
阅读全文
0 0
- java数据库连接池代码实现
- java 数据库连接池的实现代码
- Java实现数据库连接池的代码
- Java c3p0 oracle 数据库连接池 代码实现
- java数据库连接池原理,代码实现
- 代码实现数据库连接池
- 【Java面试题】数据库连接池Java代码实现
- java实现数据库连接池
- Java数据库连接池实现
- JAVA数据库连接池实现
- Java 数据库连接池 实现
- JAVA数据库连接池实现
- JAVA数据库连接池实现
- JAVA数据库连接池实现
- JAVA数据库连接池实现
- JAVA数据库连接池实现
- JAVA数据库连接池实现
- JAVA数据库连接池实现
- 选择排序之--堆排序
- js打印技巧
- jq的一些取值
- 计蒜客 八皇后问题
- lvm
- java数据库连接池代码实现
- java实现FTP多线程断点续传,上传下载!
- Android自定义对话框
- 从送外卖到建站售主机还有共享自行车说起-2017年8月江西IDC排行榜与发展报告
- 制作ubuntu根文件系统
- javascript向上向下取整
- 安全获取操作系统位数
- Android中Recyclerview使用14----RecycleView的item间距设置
- leetcode寻找最大长度的连续数对