数据库连接池c3p0优化开源框架Dbutils的简单介绍
来源:互联网 发布:淘宝ar怎么用 编辑:程序博客网 时间:2024/06/03 17:01
在编写简单的java程序时,如需用到数据库,我们一般是选择jdbc来进行连接。但,慢慢的,你会发现,用jdbc不仅步骤繁琐,而且每进行一次操作都要获取连接,在用完之后还需要释放。我们可以采用连接池c3p0来优化。下面我将结合Apache的开源框架DBUtils和连接池c3p0进行简单介绍。
DBUtils三个核心类介绍
1、dbutils:连接数据库对象---------jdbc辅助方法集合类,线程安全。
使用步骤
1.导入jar包(commons-dbutils-1.4.jar)
2.创建一个queryrunner类
queryrunner作用:操作sql语句
构造方法:
new QueryRunner(Datasource ds);
由于形参是Datasource,我们可以在此利用装饰者模式结合c3p0重写Datasource。
3.编写sql
4.执行sql
query(..):执行r操作
update(...):执行cud操作
2、QueryRunner :用于操作sql语句
3、ResultSetHandler:封装结果集 接口
下面讲一下DBUtils的快速入门
1、导入需要的jar包 mysql驱动包 c3p0包 Dbtils包
2、添加c3p0配置文件,即在src目录下的c3p0.properties 或者 c3p0-config.xml
3、创建一个工具类,用于获取c3p0连接池对象
c3p0-config.xml
<c3p0-config><!-- 默认配置,如果没有指定则使用这个配置 --><default-config><!-- 基本配置 --><property name="driverClass">com.mysql.jdbc.Driver</property><property name="jdbcUrl">jdbc:mysql://127.0.0.1:3306/day07</property><property name="user">root</property><property name="password">1234</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="itcast"><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>DataSourceUtils.java 用于获取c3p0连接池对象
import java.sql.Connection;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import javax.sql.DataSource;import com.mchange.v2.c3p0.ComboPooledDataSource;public class DataSourceUtils {private static ComboPooledDataSource ds=new ComboPooledDataSource();/** * 获取数据源 * @return 连接池 */public static DataSource getDataSource(){return ds;}/** * 获取连接 * @return 连接 * @throws SQLException */public static Connection getConnection() throws SQLException{return ds.getConnection();}/** * 释放资源 * * @param conn * 连接 * @param st * 语句执行者 * @param rs * 结果集 */public static void closeResource(Connection conn, Statement st, ResultSet rs) {closeResultSet(rs);closeStatement(st);closeConn(conn);}/** * 释放连接 * * @param conn * 连接 */public static void closeConn(Connection conn) {if (conn != null) {try {conn.close();} catch (SQLException e) {e.printStackTrace();}conn = null;}}/** * 释放语句执行者 * * @param st * 语句执行者 */public static void closeStatement(Statement st) {if (st != null) {try {st.close();} catch (SQLException e) {e.printStackTrace();}st = null;}}/** * 释放结果集 * * @param rs * 结果集 */public static void closeResultSet(ResultSet rs) {if (rs != null) {try {rs.close();} catch (SQLException e) {e.printStackTrace();}rs = null;}}}编写测试类 CURDDemo.java
public class CURDDemo {@Testpublic void insert() throws SQLException{//1.创建queryrunner类QueryRunner qr = new QueryRunner(DataSourceUtils.getDataSource());//2.编写sqlString sql="insert into category values(?,?)";//3.执行sqlqr.update(sql, "c201","厨房电器");}@Testpublic void update() throws SQLException{QueryRunner qr=new QueryRunner(DataSourceUtils.getDataSource());String sql="update category set cname = ? where cid = ?";qr.update(sql, "达电器","c000");}}可能看到这部分时,会奇怪,为什么没有Connection操作?其实查看dbutils的ap可以发现query方法有如下多个方法。
在向大佬请教之后,查看了query的源码。如下所示
prepareConnection是QueryRunner父类AbstractQueryRunner的一个方法,其实本质还是调用datasource的getconetion方法。
接着我们查看下queryRunner的解析就可以明白了
retrieve connections from this DataSource
在最后,还是得感谢南瓜大佬的解答,谢谢大佬。
- 数据库连接池c3p0优化开源框架Dbutils的简单介绍
- 数据库连接池:dbcp和c3p0,以及数据库操作框架Dbutils
- mysql:day7--开源数据库连接池(DBCP/C3P0)、DBUTILS及ext-dbutils扩展包)
- C3P0和dbutils数据库连接池封装的使用(一)
- C3P0和dbutils数据库连接池封装的使用(二)
- 数据库连接池框架:c3p0
- C3P0(开源的数据库连接池)
- 数据库连接池,DBUtils,PreparedStatement介绍
- 简单的C3P0数据库连接池配置方法
- c3p0数据库连接池的简单配置
- c3p0数据库连接池的简单使用
- c3p0数据库连接池+threadlocal线程池+DbUtils 进行数据库的操作
- c3p0数据库连接池介绍+实例
- javaWeb学习记录:c3p0数据库连接池;DBUtils工具
- Python的数据库连接池DBUtils
- C3P0配合DBUtils开源框架实现对数据库的增删改查及批处理功能实战
- C3P0开源数据库连接池的编写源码
- C3P0开源数据库连接池的编写源码
- 字符串算法——最长回文子串
- 工作周记
- 7.MariaDB笔记——cmake使用介绍二
- shell编程--数值运算
- 链表操作面试题
- 数据库连接池c3p0优化开源框架Dbutils的简单介绍
- HTML5新增的8个结构元素
- 8.MariaDB笔记——cmake使用介绍三关于库
- HTTP知识
- 9.MariaDB笔记——cmake使用介绍四安装与测试
- 计算机系统的重装教程
- 字符串笔试题
- 10.MariaDB笔记——cmake使用介绍五系统自带函数
- VMware Workstation下安装Ubuntu 64位系统