配置文件 c3p0-config.xml

<?xml version="1.0" encoding="UTF-8"?>
<c3p0-config> <default-config>
<property name="driverClass">com.mysql.jdbc.Driver</property>
<property name="jdbcUrl">jdbc:mysql://127.0.0.1:3306/db?useSSL=true</property>
<property name="user">root</property>
<property name="password">123456</property>
<property name="initialPoolSize">5</property>
<property name="maxPoolSize">20</property>
</default-config> <named-config name="mysqlConn">
<property name="driverClass">com.mysql.jdbc.Driver</property>
<property name="jdbcUrl">jdbc:mysql://127.0.0.1:3306/db?useSSL=true</property>
<property name="user">root</property>
<property name="password">123456</property>
</named-config> </c3p0-config>

C3P0连接池工具类 C3P0Utils.java

package top.try51.utils;

import java.sql.Connection;
import java.sql.SQLException;
import javax.sql.DataSource;
import com.mchange.v2.c3p0.ComboPooledDataSource; public class C3P0Utils { // 加载名称为mysqlConn 的配置(src下放置 c3p0-config.xml 配置文件)
//private static ComboPooledDataSource ds = new ComboPooledDataSource();//默认配置项
//private static ComboPooledDataSource ds = new ComboPooledDataSource("mysqlConn");//指定名称的配置项
private static ComboPooledDataSource ds = new ComboPooledDataSource("sqlServerConn");//指定名称的配置项 /**
* 定义一个ThreadLocal,绑定Connection,每个线程对应一个Connection,执行事务使用
*/
private static ThreadLocal<Connection> tl = new ThreadLocal<Connection>(); /**
*
* @return ComboPooledDataSource
*/
public static DataSource getDataSource() {
return ds;
} /**
*
* @return 由DataSource创建的 Connection
*/
public static Connection getConnection() {
try {
return ds.getConnection();
} catch (SQLException e) {
throw new RuntimeException(e);
}
} /**
*
* @return 获取当前线程绑定的Connection
* @throws SQLException
*/
public static Connection getTranConnection() throws SQLException{
//得到ThreadLocal中的connection
Connection conn = tl.get();
//判断conn是否为空,如果不为空,则说明事务已经开启
if(conn == null){
conn = getConnection();
//把当前开启的事务放入ThreadLocal中
tl.set(conn);
}
return conn;
} /**
* 开启事务,如果当前线程中没有Connection,则创建该线程对应的一个Connection
* @throws SQLException
*/
public static void beginTran() throws SQLException {
//设置事务提交为手动
getTranConnection().setAutoCommit(false);
} /**
* 提交事务
* @throws SQLException
*/
public static void commit() throws SQLException {
//得到ThreadLocal中的connection
Connection conn = getTranConnection();
//判断conn是否为空,如果为空,则说明没有开启事务
if(conn != null){
//如果conn不为空,提交事务
conn.commit();
//事务提交后,关闭连接
conn.close();
//将连接移出ThreadLocal
tl.remove();
}
} /**
* 回滚事务
* @throws SQLException
*/
public static void rollback() throws SQLException {
//得到ThreadLocal中的connection
Connection conn = getTranConnection();
//判断conn是否为空,如果为空,则说明没有开启事务,也就不能回滚事务
if(conn != null){
//事务回滚
conn.rollback();
//事务回滚后,关闭连接
conn.close();
//将连接移出ThreadLocal
tl.remove();
}
} }

C3P0连接池配置(C3P0Utils.java)的更多相关文章

  1. (30)java web的hibernate使用-c3p0连接池配置

    hibernate支持c3p0连接池 需要导入c3p0的jar包 <!-- 配置连接驱动管理类 --> <property name="hibernate.connecti ...

  2. C3p0连接池配置

    在Java开发中,使用JDBC操作数据库的四个步骤如下:   ①加载数据库驱动程序(Class.forName("数据库驱动类");)   ②连接数据库(Connection co ...

  3. Spring之c3p0连接池配置和使用

    1.导入包:c3p0和mchange包 2.代码实现方式: package helloworld.pools; import com.mchange.v2.c3p0.ComboPooledDataSo ...

  4. day39-Spring 15-Spring的JDBC模板:C3P0连接池配置

    <!-- 配置C3P0连接池 --> <bean id="dataSource2" class="com.mchange.v2.c3p0.ComboPo ...

  5. C3P0连接池配置和实现详解

    一.配置 <c3p0-config> <default-config> <!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数.Default: 3 --> ...

  6. C3P0连接池配置方式

    c3p0的配置方式分为三种,分别是 1.setters一个个地设置各个配置项 2.类路径下提供一个c3p0.properties文件 3.类路径下提供一个c3p0-config.xml文件 1.set ...

  7. Spring c3p0连接池配置

    数据库连接池 数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”.预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去.我们可以通过设定连接 ...

  8. C3P0连接池配置和实现详解(转)

    一.配置 <c3p0-config> <default-config> <!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数.Default: 3 --> ...

  9. spring hibernate4 c3p0连接池配置

    c3p0-0.9.1.2.jar,c3p0-oracle-thin-extras-0.9.1.2.jar,点此下载 <bean id="dataSource" class=& ...

随机推荐

  1. 百度云高速下载Pandownload

    对于一些文件大小比较小的文件,可以直接在网页分享中点击[下载]来下载: 但是,对于较大点的文件,点击[下载]会弹出百度云的桌面客户端软件来下载: 但但是,下载速度实在是太慢了,强迫症真真等不及啊~ 幸 ...

  2. Linux/Centos下/lib64/libc.so.6: version `GLIBC_2.14' not found问题

    Centos的某个版本下编译了一个可执行程序,复制到另外一个Centos环境下去执行,结果出现了以下错误: /lib64/libc.so.6: version `GLIBC_2.14' not fou ...

  3. python 捕捉错误,exception,traceback和sys.exc_info()比较

    import traceback,sys import requests try : requests.get('dsdsd') ##故意让他出错 except Exception,e: print ...

  4. 九度 1557:和谐答案 (LIS 变形)

    题目描述: 在初试即将开始的最后一段日子里,laxtc重点练习了英语阅读的第二部分,他发现了一个有意思的情况.这部分的试题最终的答案总是如下形式的:1.A;2.C;3.D;4.E;5.F.即共有六个空 ...

  5. cocos2d-x 3.0 在lua中调用自定义类

    环境 windows8, cocos2d-x 3.0, 现在开始安装需要的一些其它包 1. 按README.mdown文档上面要求的, 下载在windows下要安装的东东, 主要就是python2.7 ...

  6. 嵌入式之UBOOT

    嵌入式Linux系统的结构分为四个区,如图所示: 1.Bootloader区存放的是Bootloader,Coidre972开发板上使用的uboot,它负责嵌入式系统最初的硬件初始化.驱动和内核加载. ...

  7. 在linux下搭建ftp服务器【转】

    1 安装 vsftpd yum install vsftpd 2 配置 vsftpd 打开 vsftpd 文件: vi /etc/vsftpd/vsftpd.conf 初次修改前建议备份该文件 2.1 ...

  8. c++学习笔记—单链表基本操作的实现

    用c++语言实现的单链表基本操作,包括单链表的创建(包括头插法和尾插法建表).结点的查找.删除.排序.打印输出.逆置.链表销毁等基本操作. IDE:vs2013 具体实现代码如下: #include  ...

  9. intellij中使用git插件将项目上传到码云

    参考帖子: git上传本地Intellij idea 项目到码云的git仓库中(评论中有彩蛋,一定要看) IntelliJ-IDEA和Git.GitHub.Gitlab的使用 使用idea上传项目到码 ...

  10. 查询SQlServer相同表结构差异

    USE [数据库名] GO ); ); ); ); SET @DataName1='库1'; SET @DataName2='库2'; SET @TableName1='表1'; SET @Table ...