Java数据库连接池和dbutils的使用

本文介绍了数据库连接池的概念、原理及实现方法,并详细讲解了如何使用C3P0配置数据库连接池,同时展示了如何利用dbutils简化数据库操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


数据库连接池的作用:

在不使用数据库连接池的时候,每次curd操作都会打开和关闭数据库连接,这样非常浪费时间。所以便有了数据库连接池。数据库连接池顾名思义,是一个数据库连接的集合,每次需要连接只需要在这个池中获取连接,不用了就将归还给连接池。当程序消亡时,与数据库的连接也就释放了


数据库连接池的原理:

数据库连接池相当于一个容器,在java中相当于一个Connection的集合: List<Connection>  = new LinkedList<Connection>

在程序一开始运行时,就相当于创建了一个这样的集合,在每次申请一个连接时,也就相当于从这个Connection集合中获取一个Connection。

在每次释放一个连接时,就相当于往这个集合中放入一个Connection。

这样我们就可以自己写一个连接池代码如下,由于重写Connection的方法过多可以使用适配器模式;

public class MyDataBasePool implements Connection{
	
	static LinkedList<Connection> list = new LinkedList<Connection>();
	
	static { 
		String url = "jdbc:mysql:///databaseName";
		String user = "root";
		String password = "123456";
		
		//加载驱动
		try {
			Class.forName("com.jdbc.mysql.Driver");
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		}
		
		//获取5个连接,放到集合里面去
		for(int i = 0; i<5; ++i) {
			try {
				Connection conn = DriverManager.getConnection(url, user, password);
				list.add(conn);
			} catch (SQLException e) {
				e.printStackTrace();
			}
		}
	}
	
	//从集合中取出一个Connection
	public Connection getConnection() {
		
		
		return list.removeFirst();
	}
	
	//释放一个连接
	public LinkedList<Connection> releaseConnection() {
		list.addLast(this);	
		return list;
	}

}

数据库连接池的使用:

常用的数据库连接池有DBCP和C3P0;

但是DBCP没有自动回收连接的功能,C3P0有这个功能;而且相对于DBCP,C3P0使用起来非常简单

首先C3P0使用时需要引入c3p0-0.9.2.1.jar包

然后编写配置文件:

编写配置文件可以用c3p0-config.xml,也可以用c3p0.properties

当然这里的名字是固定的,而且配置文件只能放在src目录下。

建立连接的代码如下:

	ComboPooledDataSource ds = new ComboPooledDataSource();
	ds.getConnection();

对于配置文件:

如果使用c3p0.properties:

最基础的应该写入下面的信息:

c3p0.driverClass=com.mysql.jdbc.Driver
c3p0.jdbcUrl=jdbc:mysql://localhost:3306/student
c3p0.user=root
c3p0.password=123456
对于c3p0-config.xml:

如果使用这样的构造方法

ComboPooledDataSource ds = new ComboPooledDataSource();

只需要写入下面的信息:

<c3p0-config>
	<!-- 默认配置,如果没有指定则使用这个配置 -->
	<default-config>
		<!-- 基本配置 -->
		<property name="driverClass">com.mysql.jdbc.Driver</property>
		<property name="jdbcUrl">jdbc:mysql://127.0.0.1:3306/xxxx</property>
		<property name="user">root</property>
		<property name="password">123456</property>
	
		<!--扩展配置-->
		<property name="checkoutTimeout">30000</property>
		<property name="idleConnectionTestPeriod">30</property>
		<property name="initialPoolSize">10</property>
		<property name="maxIdleTime">30</property>
		<property name="maxPoolSize">100</property>
		<property name="minPoolSize">10</property>
		<property name="maxStatements">200</property>
	</default-config> 
</c3p0-config> 

如果使用自定义配置:

就可以使用这个带一个参数构造函数

ComboPooledDataSource ds = new ComboPooledDataSource(String configName);
那么他的配置文件应该是这样:

<c3p0-config>
	<!-- 默认配置,如果没有指定则使用这个配置 -->
	<default-config>
		<!-- 基本配置 -->
		<property name="driverClass">com.mysql.jdbc.Driver</property>
		<property name="jdbcUrl">jdbc:mysql://127.0.0.1:3306/student</property>
		<property name="user">root</property>
		<property name="password">123456</property>
	
		<!--扩展配置-->
		<property name="checkoutTimeout">30000</property>
		<property name="idleConnectionTestPeriod">30</property>
		<property name="initialPoolSize">10</property>
		<property name="maxIdleTime">30</property>
		<property name="maxPoolSize">100</property>
		<property name="minPoolSize">10</property>
		<property name="maxStatements">200</property>
	</default-config> 
	
	<!-- 命名的配置 -->
	<named-config name="configName">
		<property name="driverClass">com.mysql.jdbc.Driver</property>
		<property name="jdbcUrl">jdbc:mysql://127.0.0.1:3306/xxxx</property>
		<property name="user">root</property>
		<property name="password">1234</property>
		
		
		<!-- 如果池中数据连接不够时一次增长多少个 -->
		<property name="acquireIncrement">5</property>
		<property name="initialPoolSize">20</property>
		<property name="minPoolSize">10</property>
		<property name="maxPoolSize">40</property>
		<property name="maxStatements">20</property>
		<property name="maxStatementsPerConnection">5</property>
	</named-config>
</c3p0-config> 
其中configName就是构造函数里面的参数;

在使用自定义的配置文件时,当未找到这个参数时,他就会自动读取默认的配置文件;所以配置文件里面必须要有默认的配置文件。


dbutils的使用:

dbutils是用来简化数据库操作的:

当进行一个插入操作时,需要进行以下步骤:

1. 建立连接(Connection)

2. 编写sql语句

3. 创建语句执行者(PreparedStatement)

4. 更新操作(executeUpdate)

5. 关闭PreparedStatement

6. 关闭Connection


但是如果用dbutils:

只需要如下几步

QueryRunner qr = new QueryRunner(new ComboPooledDataSource());
		String sql = "select * from student";
		String sqlInsert = "insert into student values(?, ?, ?, ?)";
		try {
			qr.update(sqlInsert, "10078", "老王", "计算机", "计算机专业");
				
		} catch (SQLException e) {
			e.printStackTrace();
		} finally {
				DbUtils.close();
}

所以dbutils大大简化了我们对数据库的操作。

在使用dbutils时,需要引入commons-dbutils-1.4.jar包。






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值