数据库连接池----DBCP & C3P0

一 、 DBCP

 1、DBCP简介  

       DBCP(DataBase Connection Pool)数据库连接池,是Java数据库连接池的一种,由Apache开发,通过数据库连接池,可以让程序自动管理数据库连接的释放和断开。

2、DBCP连接数据库

(1)、导入 commons-pool-1.5.6.jar 和 commons-dbcp-1.4.jar ,导入 dbcpconfig.properties 配置文件到 src 文件夹下,  dbcpconfig.properties配置文件代码如下 :

#连接设置
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/bank
username=root
password=123456

#<!-- 初始化连接 -->
initialSize=10

#最大连接数量
maxActive=50

#<!-- 最大空闲连接 -->
maxIdle=20

#<!-- 最小空闲连接 -->
minIdle=5

#<!-- 超时等待时间以毫秒为单位 6000毫秒/1000等于60秒 -->
maxWait=60000


#JDBC驱动建立连接时附带的连接属性属性的格式必须为这样:[属性名=property;] 
#注意:"user" 与 "password" 两个属性会被明确地传递,因此这里不需要包含他们。
connectionProperties=useUnicode=true;characterEncoding=gbk

#指定由连接池所创建的连接的自动提交(auto-commit)状态。
defaultAutoCommit=true

#driver default 指定由连接池所创建的连接的事务级别(TransactionIsolation)。
#可用值为下列之一:(详情可见javadoc。)NONE,READ_UNCOMMITTED, READ_COMMITTED, REPEATABLE_READ, SERIALIZABLE
defaultTransactionIsolation=READ_UNCOMMITTED

(2)、编写测试类 DBCPDemo02  ,代码如下 :

package czm.dbcp;

import java.io.FileInputStream;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.util.Properties;

import javax.sql.DataSource;

import org.apache.commons.dbcp.BasicDataSource;
import org.apache.commons.dbcp.BasicDataSourceFactory;
import org.junit.Test;

import com.itheima.uitl.JDBCUtil;

public class DBCPDemo02 {
     @Test
     public void testDBCP02(){
         
    	 Connection conn = null;
     	PreparedStatement ps = null;
     	
     	try {
     	         //引入配置文件,连接数据库
     		BasicDataSourceFactory factory = new BasicDataSourceFactory();
     		Properties properties = new Properties();
     		InputStream is = new FileInputStream("src//dbcpconfig.properties");
     		properties.load(is);
     		DataSource dataSource = factory.createDataSource(properties);
     		
     	                 //得到连接对象
 			conn = dataSource.getConnection();
 			
 			String sql = "insert into account values(null,?,?)";
 			
 			ps = conn.prepareStatement(sql);
 			ps.setString(1, "Jony");
 			ps.setInt(2, 2000);
 			
 			ps.executeUpdate();
 			
 		} catch (Exception e) {
 			// TODO Auto-generated catch block
 			e.printStackTrace();
 		}finally {
 			JDBCUtil.release(conn, ps);
 		}
     }
}

二 、C3P0

1 、C3P0 简介

     C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。目前使用它的开源项目有Hibernate,Spring等。

2 、 C3P0 连接数据库

(1) 、导入 c3p0-0.9.1.2.jar,在src目录下新建 c3p0-config.xml 配置文件,代码如下 :

<?xml version="1.0" encoding="UTF-8"?>
<c3p0-config>
  <default-config>
     //设置数据库信息
    <property name="driverClass">com.mysql.jdbc.Driver</property>
    <property name="jdbcUrl">jdbc:mysql://localhost/bank</property>
    <property name="user">root</property>
    <property name="password">123456</property>
    
    <property name="maxIdleTime">30</property>
    <property name="maxPoolSize">100</property>
    <property name="minPoolSize">10</property>
    <property name="maxStatements">200</property>

    <user-overrides user="test-user">
      <property name="maxPoolSize">10</property>
      <property name="minPoolSize">1</property>
      <property name="maxStatements">0</property>
    </user-overrides>

  </default-config>

  <!-- This app is massive! -->
  <named-config name="intergalactoApp"> 
    <property name="acquireIncrement">50</property>
    <property name="initialPoolSize">100</property>
    <property name="minPoolSize">50</property>
    <property name="maxPoolSize">1000</property>

    <!-- intergalactoApp adopts a different approach to configuring statement caching -->
    <property name="maxStatements">0</property> 
    <property name="maxStatementsPerConnection">5</property>

    <!-- he's important, but there's only one of him -->
    <user-overrides user="master-of-the-universe"> 
      <property name="acquireIncrement">1</property>
      <property name="initialPoolSize">1</property>
      <property name="minPoolSize">1</property>
      <property name="maxPoolSize">5</property>
      <property name="maxStatementsPerConnection">50</property>
    </user-overrides>
  </named-config>
</c3p0-config>

 (2) 、编写测试类 C3P0Demo02 ,代码如下 :

package czm.c3p0;

import java.sql.Connection;
import java.sql.PreparedStatement;

import org.junit.Test;

import com.itheima.uitl.JDBCUtil;
import com.mchange.v2.c3p0.ComboPooledDataSource;

public class C3P0Demo02 {
	@Test
    public void testC3P0(){
       Connection conn = null;
       PreparedStatement ps = null;
		try {
		     
			ComboPooledDataSource dataSource = new ComboPooledDataSource();
   	    	                         	     	      	      	           	
 			conn = dataSource.getConnection();
 			
 			String sql = "insert into account values(null,?,?)";
 			
 			ps = conn.prepareStatement(sql);
 			ps.setString(1, "Honey");
 			ps.setInt(2, 5000);
 			
 			ps.executeUpdate();
 			
 		} catch (Exception e) {
 			// TODO Auto-generated catch block
 			e.printStackTrace();
 		}finally {
 			JDBCUtil.release(conn, ps);
 		}
    }
}

备注 :相关jar 包下载链接 :  https://pan.baidu.com/s/1u-aBnKHrpR1KP41Qjyx3yA      提取码:evez 

猜你喜欢

转载自blog.csdn.net/Rachel_pan/article/details/84977921