一、连接池
在实际的开发应用中,我们常常会对数据库进行大量的高并发的访问,而最原始的连接和操作方式并不能满足这种大量的访问
,程序员为了追求更方便、更快捷、更科学安全的开发。第三方的工具类和Dao层的框架就应运而生了。DBCP连接池、和C3P0连
接池就是2个常见的开源数据库连接池。
在与数据库进行交互的过程中,获得连接”和“释放资源”是非常消耗系统资源的两个过程,为了解决此类性能问题,通常情况
我们采用连接池技术,来共享连接Connection。这样我们就不需要每次都创建连接、释放连接了,这些操作都交给了连接池。用的
时候从连接池里拿出来,用完了在给他放回去,下次使用时还可以接着用。
同数据库的链接规范(JDBC)一样,java为数据库连接池也提供了一套规范(接口)- javax.sql.DataSource,各个厂商需要
让自己的连接池实现这个接口。这样就方便了应用程序的扩展和我们的使用。
(一)DBCP连接池
DBCP连接池他是一个开源的连接池,属于Apache家族的一员,为Tomcat的内置连接池(自己的土,自己的地…)
1、导入炸包
使用第三方工具类的第一件事就是导入jar包,然后Build Patch一下,为了方便jar包的管理(另一方面满足于强迫症患者的
整理欲望)一般都在工程下新建一个lib文件夹用来存放炸包。
需要导入的jar包:
* commons-dbcp-1.4.jar
* commons-pool-1.5.6.jar
2、DBCP连接池的使用
连接数据库的操作是一个频繁使用,代码重复的操作,可以将其抽取成一个工具类。
Java为数据库连接池也提供了一套规范接口:DataSource,它是java中提供的连接池,作为 DriverManager 工具的替代项。
而DBCP包则提供了DataSource接口的实现类 - BasicDataSource类。
栗子:
public class JdbcUtils {
//定义一个连接池
private static BasicDataSource bd = new BasicDataSource();
//工具类,私有他的无参构造
private JdbcUtils() {
super();
}
//使用静态代码块进行连接池的属性配置
//静态代码块是随着类的加载而加载的且只加载一次(节省资源)
static {
/*
* 必须设置的项
*/
//设置mySQL的驱动
bd.setDriverClassName(“com.mysql.jdbc.Driver”);
//设置要连接数据库的URL
bd.setUrl(“jdbc:mysql://localhost:3306/mydb”);
//设置用户名
bd.setUsername(“root”);
//设置数据库密码
bd.setPassword(“root”);
/*
* 选择设置的项,不设置的话会有默认值跟着
*/
//初始化连接数
bd.setInitialSize(10);
//最大连接数
bd.setMaxActive(15);
//最大空闲连接数
bd.setMaxIdle(6);
//最小空闲连接数
bd.setMinIdle(3);
}
/**
* 获取连接池对象
* @return bd 连接池
*/
public static DataSource getDataSource() {
return bd;
}
}
(二)C3P0连接池
C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。目前使用它的开源项目有
Hibernate,Spring等。(百度百科)
C3P0连接池有自动回收空闲连接的功能,而DBCP没有自动回收空闲连接的功能。
1、导入jar包
同DBCP的使用步骤一样,第一步要导入相关的jar包:
c3p0-0.9.1.2.jar
2、C3P0连接池的使用
通过查看帮助文档(doc目录下的index.html文件里边有个快速入门)发现C3P0可以通过手动或者配置文件的方式使用。
* 通过手动进行配置
public static void main(String[] args) throws Exception {
// 获得C3P0连接池对象
ComboPooledDataSource source = new ComboPooledDataSource();
// 设置驱动
source.setDriverClass(“com.mysql.jdbc.Driver”);
// 设置连接库的路径
source.setJdbcUrl(“jdbc:mysql:///mydb”);
// 设置用户名
source.setUser(“root”);
// 设置密码
source.setPassword(“root”);
// 通过连接池创建一个QueryRunner对象
QueryRunner runner = new QueryRunner(source);
// 测试
String sql = “SELECT * FROM users”;
List
* query(Connection conn, String sql, ResultSetHandler rsh, Object… params) ,用来完成表数据的查询操作。
* new QueryRunner(DataSource ds) ,带参构造,使用带参构造时调用update,query方法无需要传入Connection对象
* update(String sql, Object… params) ,用来完成表数据的增加、删除、更新操作。
* query(String sql, ResultSetHandler rsh, Object… params) ,用来完成表数据的查询操作。
栗子:
* 无参构造的update方法
/**
* 增加操作
* @throws SQLException
*/
private static void method01() throws SQLException {
// 通过工具类获得连接
Connection connection = JdbcUtilsConfig.getConnection();
// 获得QueryRunner对象
QueryRunner runner = new QueryRunner();
// 编写sql语句
String insert = “INSERT INTO sort(sname,sprice,sdesc) VALUES(?,?,?)”;
// 执行update方法,也可以将数据存到Object数组里然后传入数组,返回值为影响的行数
int update = runner.update(connection, insert, “家具”, 1000, “很好用”);
System.out.println(update);
}
/**
* 更新操作
*
* @throws SQLException
*/
private static void method02() throws SQLException {
// 通过工具类获得连接
Connection connection = JdbcUtilsConfig.getConnection();
// 获得QueryRunner对象
QueryRunner runner = new QueryRunner();
// 编写sql语句
String s = “UPDATE sort SET sname=?,sprice=?,sdesc=? WHERE sid=4”;
// 执行update方法
runner.update(connection, s, “花卉”, 100, “买给你爱的人”);
//安静的关闭
DbUtils.closeQuietly(connection);
}
/**
* 删除操作
*
* @throws SQLException
*/
private static void method03() throws SQLException {
// 通过工具类获得连接
Connection connection = JdbcUtilsConfig.getConnection();
// 创建一个QueryRunner对象,用来完成SQL语句的执行
QueryRunner qr = new QueryRunner();
// 执行SQL语句
String sql = “DELETE FROM zhangwu WHERE name = ?”;
Object[] params = { “股票收入” };
int line = qr.update(connection, sql, params);
// 结果集的处理,影响的行数
System.out.println(“line=” + line);
}
* 有参构造的query方法
public static void main(String[] args) throws Exception {
// 通过工具类获得连接池对象
DataSource dataSource = C3p0Utils.getDataSource();
// 通过连接池创建一个QueryRunner对象
QueryRunner runner = new QueryRunner(dataSource);
// 编写sql语句
String sql = “SELECT * FROM users”;
// 执行query方法传入ArrayListHandler返回集合
List