C3P0

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: C3P0

C3P0

C3p0

  • 是一个开源的JDBC连接池,目前使用它的开源项目是Hibernate、Spring

C3P0和dbcp区别:

  • dbcp没有自动回收空闲连接的功能
  • C3P0有自动回收空闲连接的功能

需要用到的jar包

c3p0-0.9.5.5、mchange-commons-java-0.2.19

1、导包

2、在类目录下加入C3P0的配置文件:c3p0-config.xml

<?xmlversion="1.0" encoding="UTF-8"?>

<c3p0-config>

<!--

C3P0的缺省(默认)配置,

如果在代码中“ComboPooledDataSource ds = new ComboPooledDataSource();”这样写

就表示使用的是C3P0的缺省(默认)配置信息来创建数据源

-->

<default-config>

<propertyname="driverClass">com.mysql.jdbc.Driver</property>

<propertyname="jdbcUrl">jdbc:mysql://localhost:3306/jdbcStudy?

useUnicode=true&amp;characterEncoding=utf8&amp;useSSL=true</property>

<propertyname="user">root</property>

<propertyname="password">123456</property>

<propertyname="acquireIncrement">5</property>

<propertyname="initialPoolSize">10</property>

<propertyname="minPoolSize">5</property>

<propertyname="maxPoolSize">20</property>

</default-config>

<!--

C3P0的命名配置,

如果在代码中“ComboPooledDataSource ds = new

ComboPooledDataSource("MySQL");”这样写就表示使用的是name是MySQL的配置信息来创建数据

-->

<named-configname="MySQL">

<propertyname="driverClass">com.mysql.jdbc.Driver</property>

<propertyname="jdbcUrl">jdbc:mysql://localhost:3306/jdbcStudy?

useUnicode=true&amp;characterEncoding=utf8&amp;useSSL=true</property>

<propertyname="user">root</property>

<propertyname="password">123456</property>

<propertyname="acquireIncrement">5</property>

<propertyname="initialPoolSize">10</property>

<propertyname="minPoolSize">5</property>

<propertyname="maxPoolSize">20</property>

</named-config>

</c3p0-config>

 

3、创建工具类

packagecom.kuang.datasource.utils;

importjava.sql.Connection;

importjava.sql.ResultSet;

importjava.sql.SQLException;

importjava.sql.Statement;

importcom.mchange.v2.c3p0.ComboPooledDataSource;

//数据库连接工具类

publicclassJdbcUtils_C3P0 {

   privatestaticComboPooledDataSourceds=null;

   //在静态代码块中创建数据库连接池

   static{

       try{

           //通过代码创建C3P0数据库连接池

           /*ds = new ComboPooledDataSource();

           ds.setDriverClass("com.mysql.jdbc.Driver");

           ds.setJdbcUrl("jdbc:mysql://localhost:3306/jdbcstudy");

           ds.setUser("root");

           ds.setPassword("123456");

           ds.setInitialPoolSize(10);

           ds.setMinPoolSize(5);

           ds.setMaxPoolSize(20);*/

           //通过读取C3P0的xml配置文件创建数据源,C3P0的xml配置文件c3p0-config.xml必须放在src目录下

           //ds = new ComboPooledDataSource();//使用C3P0的默认配置来创建数据源

           ds=newComboPooledDataSource("MySQL");//使用C3P0的命名配置来创建数据源

           ////////////////////////////////////////////

       }catch (Exceptione) {

           thrownewExceptionInInitializerError(e);

       }

   }

   //从数据源中获取数据库连接

   publicstaticConnectiongetConnection() throwsSQLException{

       //从数据源中获取数据库连接

       returnds.getConnection();

       /////////////////////////////////

   }

   //释放资源

   publicstaticvoidrelease(Connectionconn,Statementst,ResultSetrs){

       if(rs!=null){

           try{

               //关闭存储查询结果的ResultSet对象

               rs.close();

           }catch (Exceptione) {

               e.printStackTrace();

           }

           rs=null;

       }

       if(st!=null){

           try{

               //关闭负责执行SQL命令的Statement对象

               st.close();

           }catch (Exceptione) {

               e.printStackTrace();

           }

       }

       if(conn!=null){

           try{

               //将Connection连接对象还给数据库连接池

               conn.close();

           }catch (Exceptione) {

               e.printStackTrace();

           }

       }

   }

}

 

测试

packagecom.kuang.datasource;

importcom.kuang.datasource.utils.JdbcUtils_C3P0;

importcom.kuang.datasource.utils.JdbcUtils_DBCP;

importjava.sql.Connection;

importjava.sql.PreparedStatement;

importjava.sql.ResultSet;

importjava.util.Date;

publicclassC3P0Test {

   publicstaticvoidmain(String[] args) {

       Connectionconn=null;

       PreparedStatementst=null;

       ResultSetrs=null;

       try{

           //获取数据库连接

           conn=JdbcUtils_C3P0.getConnection();

           ///////////////////////////////

           Stringsql="insert into users(id,name,password,email,birthday)

           values(?,?,?,?,?)";

           st=conn.prepareStatement(sql);

           st.setInt(1, 6);//id是int类型的

           st.setString(2, "kuangshen");//name是varchar(字符串类型)

           st.setString(3, "123");//password是varchar(字符串类型)

           st.setString(4, "24736743@qq.com");//email是varchar(字符串类型)

           st.setDate(5, newjava.sql.Date(new

           Date().getTime()));//birthday是date类型

           inti=st.executeUpdate();

           if (i>0){

               System.out.println("插入成功");

           }

       }catch (Exceptione) {

           e.printStackTrace();

       }finally{

           //释放资源

           JdbcUtils_C3P0.release(conn, st, rs);

           ////////////////////////

       }

   }

}


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
2024阿里云双11,WoSign SSL证书优惠券使用攻略
2024阿里云“11.11金秋云创季”活动主会场,阿里云用户通过完成个人或企业实名认证,可以领取不同额度的满减优惠券,叠加折扣优惠。用户购买WoSign SSL证书,如何叠加才能更加优惠呢?
1031 3
AI:互联网程序设计竞赛之蓝桥杯大赛的简介、奖项设置、大赛内容以及蓝桥杯与ACM(ICPC)的四个维度对比之详细攻略
AI:互联网程序设计竞赛之蓝桥杯大赛的简介、奖项设置、大赛内容以及蓝桥杯与ACM(ICPC)的四个维度对比之详细攻略
AI:互联网程序设计竞赛之蓝桥杯大赛的简介、奖项设置、大赛内容以及蓝桥杯与ACM(ICPC)的四个维度对比之详细攻略
Laravel Predis Error while reading line from the server.
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/sinat_21158419/article/details/53610445 问题...
3972 0
面试官问:如果有100个请求,你如何使用Promise控制并发?
面试官问:如果有100个请求,你如何使用Promise控制并发?
427 0
|
5月前
|
Hashtable 和 HashMap 的区别
【8月更文挑战第22天】
186 0
深入理解PHP中的生成器(Generators)
【6月更文挑战第22天】在PHP的世界里,生成器是一个强大的功能,它允许你定义一个迭代器,而不需要实现迭代器接口。通过一个简单的关键字 "yield",你可以生成一个序列的值,每次只产生一个值,而不是一次性计算并存储所有的值。本文将带你深入了解生成器的工作原理,以及如何有效地使用它们来优化内存使用和提高代码效率。
WebView加载https的空白及图片加载不了的问题
WebView加载https的空白及图片加载不了的问题
313 0
C# | 上位机开发新手指南(一)概述
C#,是微软主推的编程语言。它在工业控制、自动化、物联网等领域应用非常广泛。由于国内在工业控制领域技术发展路径的原因,早期的自动化控制面板由Window环境提供,大量的MFC、VB6控制应用被部署在了工厂车间。在用户习惯和界面环境的双料加持下,给C#在工业领域的推广打下的坚实的基础。使用C#进行上位机开发已经是行业内的主流选择。 如果正在读文章的你准备或正在从事C#的上位机开发,本专栏将会是您在这条路线上的路标。欢迎一同打卡每一个节点。
1608 0
C# | 上位机开发新手指南(一)概述
Laravel:whereIn子查询
Laravel:whereIn子查询
208 0