
commons-dbcp-1.4.jar
commons-pool-1.5.5.jar
package com.atguigu4.connection;import java.io.File;import java.io.FileInputStream;import java.sql.Connection;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;public class DBCPTest {/**** @Description 测试DBCP的数据库连接池技术* @author shkstart* @throws SQLException* @date 下午3:20:50*///方式一:不推荐@Testpublic void testGetConnection() throws SQLException{//创建了DBCP的数据库连接池BasicDataSource source = new BasicDataSource();//设置基本信息source.setDriverClassName("com.mysql.jdbc.Driver");source.setUrl("jdbc:mysql:///test");source.setUsername("root");source.setPassword("abc123");//还可以设置其他涉及数据库连接池管理的相关属性:source.setInitialSize(10);source.setMaxActive(10);//。。。Connection conn = source.getConnection();System.out.println(conn);}//方式二:推荐:使用配置文件@Testpublic void testGetConnection1() throws Exception{Properties pros = new Properties();//方式1:// InputStream is = ClassLoader.getSystemClassLoader().getResourceAsStream("dbcp.properties");//方式2:FileInputStream is = new FileInputStream(new File("src/dbcp.properties"));pros.load(is);DataSource source = BasicDataSourceFactory.createDataSource(pros);Connection conn = source.getConnection();System.out.println(conn);}}
dbcp.properties
driverClassName=com.mysql.jdbc.Driverurl=jdbc:mysql:///testusername=rootpassword=abc123initialSize=10
放在JDBCutil.java
不会关掉连接池
//创建一个DBCP数据库连接池private static DataSource source;static{try {Properties pros = new Properties();FileInputStream is = new FileInputStream(new File("src/dbcp.properties"));pros.load(is);source = BasicDataSourceFactory.createDataSource(pros);} catch (Exception e) {e.printStackTrace();}}public static Connection getConnection2() throws Exception{Connection conn = source.getConnection();return conn;}