【具备全程事务控制的JDBC连接管理器】

Hibernate事务具备全局管理能力,配合Spring框架就可以在BO层完成DAO操作和事务控制。当然,传统的JDBC是不具备这个能力的,所以要自己开发一个连接管理器框架,来管理线程范围内的数据库连接和事务控制。

  [java]

  package edu.softparty.base.dbunit;

  import java.sql.Connection;

  import java.sql.ResultSet;

  import java.sql.SQLException;

  import java.sql.Statement;

  import javax.sql.DataSource;

  /**

  * 连接管理器类

  */

  public class ConnectionManager {

  /**

  * 空的事务对象

  */

  private static final Transaction EMPTY_TRANSACTION = new Transaction() {

  public void rollback() throws SQLException {

  }

  public void commit() throws SQLException {

  }

  };

  /**

  * 负责提交和回滚的事务对象

  */

  private static final Transaction TRANSACTION = new Transaction() {

  public void rollback() throws SQLException {

  Connection connection = connectionHolder.get();

  if (connection != null) {

  if (connection.getAutoCommit() == false) {

  connection.rollback();

  }

  connection.close();

  connectionHolder.remove();

  }

  }

  public void commit() throws SQLException {

  Connection connection = connectionHolder.get();

  if (connection != null) {

  if (connection.getAutoCommit() == false) {

  connection.commit();

  }

  connection.close();

  connectionHolder.remove();

  }

  }

  };

转载于:https://www.cnblogs.com/mfxp/p/3312326.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值