Spring整合c3p0和druid数据库连接池
文章目录
1.数据库连接池的作用
- 数据源(连接池)是
提高程序性能
如出现的 - 事先实例化数据源,
初始化部分连接资源
- 使用连接资源时从数据源中
获取
- 使用完毕后将连接资源
归还
给数据源
常见的数据源(连接池):DBCP、C3P0、BoneCP、Druid等
2.数据源的开发步骤
- 导入数据源的坐标和数据库驱动坐标
- 创建数据源对象
- 设置数据源的基本连接数据
- 使用数据源获取连接资源和归还连接资源
3.手动创建数据源
1.导入c3p0和druid的坐标
<!-- C3P0连接池 -->
<dependency>
<groupId>c3p0</groupId>
<artifactId>c3p0</artifactId>
<version>0.9.1.2</version>
</dependency>
<!-- Druid连接池 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.10</version>
</dependency>
2.导入mysql数据库驱动坐标
<!-- mysql驱动 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.39</version>
</dependency>
3.手动创建c3p0连接池
/**
* 手动创建c3p0连接池
* <p>
* 输出:
* com.mchange.v2.c3p0.impl.NewProxyConnection@668bc3d5
*/
@Test
public void c3p0_test1() throws PropertyVetoException, SQLException {
//创建数据源
ComboPooledDataSource dataSource = new ComboPooledDataSource();
//设置数据库连接参数
dataSource.setDriverClass("com.mysql.jdbc.Driver");
dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/test");
dataSource.setUser("root");
dataSource.setPassword("root");
//获得连接对象
Connection connection = dataSource.getConnection();
System.out.println(connection);
}
/**
* 读取jdbc.properties创建c3p0连接池
* <p>
* 输出:com.mchange.v2.c3p0.impl.NewProxyConnection@3cda1055
*/
@Test
public void c3p0_test2() throws PropertyVetoException, SQLException {
//记载类路径下的jdbc.properties
ResourceBundle rb = ResourceBundle.getBundle("jdbc");
//创建数据源
ComboPooledDataSource dataSource = new ComboPooledDataSource();
//设置数据库连接参数
dataSource.setDriverClass(rb.getString("jdbc.driver"));
dataSource.setJdbcUrl(rb.getString("jdbc.url"));
dataSource.setUser(rb.getString("jdbc.username"));
dataSource.setPassword(rb