DbUtil组件及C3P0数据库连接池组件的使用

Posted 酒香逢

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DbUtil组件及C3P0数据库连接池组件的使用相关的知识,希望对你有一定的参考价值。

DbUtils

Apache 组织提供的一个开源 JDBC工具类库,它是对JDBC的简单封装,学习成本极低,并且使用dbutils能极大简化jdbc编码的工作量,同时也不会影响程序的性能。

使用commons-dbutils 的核心工具类:QueryRunner,该类定义了所有操作数据库的方法

如方法:T query(Connection conn ,String sql, ResultSetHandler<T> rsh, Object... params)

DbUtils提供的封装结果的一些对象:

1) BeanHandler  查询返回单个对象(常用)

2) BeanListHandler  查询返回list集合,集合元素是指定的对象(常用

3)  ArrayHandler  查询返回结果记录的第一行,封装对对象数组, 即返回:Object[]

4)  ArrayListHandler 把查询的每一行都封装为对象数组,再添加到list集合中

5)  ScalarHandler 查询返回结果记录的第一行的第一列  (在聚合函数统计的时候用)

6)  MapHandler  查询返回结果的第一条记录封装为map

使用:

前提:实体类必须符合javabean规范,并且实体类中的字段必须与数据库表的字段相同。引入jar文件 : commons-dbutils-1.6.jar

1、简单创建一个工具类JdbcUtil,方便代码调用

 1 public class JdbcUtil {
 2     private static String url = "jdbc:mysql:///test01";
 3     private static String user = "root";
 4     private static String password = "123456";
 5     //获取QueryRunner对象
 6     public static QueryRunner getQueryRunner(){
 7         return new QueryRunner();
 8     }
 9     //获取连接
10     public static Connection getConnection(){
11         try {
12             Class.forName("com.mysql.jdbc.Driver");
13             return DriverManager.getConnection(url, user, password);
14         } catch (Exception e) {
15             e.printStackTrace();
16             throw new RuntimeException(e);
17         }
18     }
19 }

 

 2、调用query方法

 1 @Test
 2     public void test1() {
 3         List<Student> list = null;
 4         try {
 5             Connection conn = JdbcUtil.getConnection();
 6             list = JdbcUtil.getQueryRunner().query(conn, "select * from Student"
 7                     , new BeanListHandler<Student>(Student.class));
 8         } catch (Exception e) {
 9             e.printStackTrace();
10             throw new RuntimeException(e);
11         }
12         if(list !=null){
13             for (Student student : list) {
14                 System.out.println(student);
15             }
16         }
17     } 

使用C3P0数据库连接池组件优化程序性能

C3P0核心类:ComboPooledDataSource

使用:

前提 引入jar文件 : c3p0-0.9.1.2.jar
方式一:不使用配置文件

1、简单建立一个jdbc工具类,方便方法调用

 1 import java.beans.PropertyVetoException;
 2 import java.sql.Connection;
 3 import org.apache.commons.dbutils.QueryRunner;
 4 
 5 import com.mchange.v2.c3p0.ComboPooledDataSource;
 6 
 7 
 8 public class JdbcUtil {
 9     private static String url = "jdbc:mysql:///test01";
10     private static String user = "root";
11     private static String password = "123456";
12     private static ComboPooledDataSource dataSource = null;
13     private Connection con = null;
14     static{
15         //初始化操作
16         dataSource = new ComboPooledDataSource();// 使用默认的配置
17         dataSource.setJdbcUrl(url);//设置连接字符串
18         try {
19             dataSource.setDriverClass("com.mysql.jdbc.Driver");//获取驱动
20         } catch (PropertyVetoException e) {
21             e.printStackTrace();
22         }
23         dataSource.setUser(user);//用户名
24         dataSource.setPassword(password);//密码
25         dataSource.setInitialPoolSize(3);//初始化时获取三个连接
26         dataSource.setMaxPoolSize(6);//连接池中保留的最大连接数
27         dataSource.setMaxIdleTime(60); //最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃
28     }
29     
30     //获取QueryRunner对象
31     public static QueryRunner getQueryRunner(){
32         return new QueryRunner(dataSource);
33     }
34     //获取连接纯 通过c3p0核心类对象获取(此例子没用到该方法)
35     public static Connection getConnection(){
36         try {
37             return dataSource.getConnection();
38         } catch (Exception e) {
39             e.printStackTrace();
40             throw new RuntimeException(e);
41         }
42     }
43 }

 

2、执行测试

 1 @Test
 2     public void test1() {
 3         List<Student> list = null;
 4         try {
 5             Connection conn = JdbcUtil.getConnection();
 6             list = JdbcUtil.getQueryRunner().query("select * from Student"
 7                     , new BeanListHandler<Student>(Student.class));
 8         } catch (Exception e) {
 9             e.printStackTrace();
10             throw new RuntimeException(e);
11         }
12         if(list !=null){
13             for (Student student : list) {
14                 System.out.println(student);
15             }
16         }
17     }

 

方式二:使用配置文件来初始化

1、将C3P0配置文件c3p0-config.xml放置在工程src目录下

c3p0-config.xml

 1 <c3p0-config>
 2   <!-- 默认加载配置 -->
 3   <default-config>
 4      <property name="driverClass">com.mysql.jdbc.Driver</property> 
 5      <property name="jdbcUrl">jdbc:mysql://localhost:3306/test01</property> 
 6      <property name="user">root</property> 
 7      <property name="password">123456</property> 
 8      <property name="initialPoolSize">5</property> 
 9      <property name="maxPoolSize">10</property> 
10   </default-config>
11   <!-- 指定名称加载配置 -->
12   <named-config name="C3P0TestName">
13     <property name="driverClass">com.mysql.jdbc.Driver</property> 
14      <property name="jdbcUrl">jdbc:mysql://localhost:3306/test01</property> 
15      <property name="user">root</property> 
16      <property name="password">123456</property> 
17      <property name="initialPoolSize">5</property> 
18      <property name="maxPoolSize">10</property> 
19   </named-config>
20   
21 </c3p0-config>

 

2、简单编写一个工具类,方便代码调用

 1 import java.sql.Connection;
 2 import org.apache.commons.dbutils.QueryRunner;
 3 
 4 import com.mchange.v2.c3p0.ComboPooledDataSource;
 5 
 6 
 7 public class JdbcUtil {
 8     private static ComboPooledDataSource dataSource = null;
 9     static{
10         //初始化操作
11         // 自动加载src目录下c3p0的配置文件【c3p0-config.xml】
12         dataSource = new ComboPooledDataSource();// 使用默认的配置
13         //使用c3p0-config.xml配置文件中named-config的name属性为C3P0TestName的配置
14         //dataSource = new ComboPooledDataSource("C3P0TestName");
15     }
16     
17     //获取QueryRunner对象
18     public static QueryRunner getQueryRunner(){
19         return new QueryRunner(dataSource);
20     }
21     //获取连接纯 通过c3p0核心类对象获取(此例子没用到该方法)
22     public static Connection getConnection(){
23         try {
24             return dataSource.getConnection();
25         } catch (Exception e) {
26             e.printStackTrace();
27             throw new RuntimeException(e);
28         }
29     }
30 }

 

3、执行测试

 1 @Test
 2     public void test1() {
 3         List<Student> list = null;
 4         try {
 5             Connection conn = JdbcUtil.getConnection();
 6             list = JdbcUtil.getQueryRunner().query("select * from Student"
 7                     , new BeanListHandler<Student>(Student.class));
 8         } catch (Exception e) {
 9             e.printStackTrace();
10             throw new RuntimeException(e);
11         }
12         if(list !=null){
13             for (Student student : list) {
14                 System.out.println(student);
15             }
16         }
17     }

 

完毕.

 

以上是关于DbUtil组件及C3P0数据库连接池组件的使用的主要内容,如果未能解决你的问题,请参考以下文章

MySQL最全存储引擎索引使用及SQL优化的实践

数据库连接池c3p0常用配置说明及使用

C3P0连接池工具类实现步骤及方法

数据库连接池DBCP的使用

基于Apache组件,分析对象池原理

Java学习:数据库连接池DBCP的使用