Oracle数据库端测试环境见:http://www.cnblogs.com/yshyee/p/4392328.html

package com.mw.utils;

import java.sql.Connection;
import java.sql.SQLException;
import java.util.logging.Level;
import java.util.logging.Logger; /**
* @author y
* @date 2015-4-4 13:33:02
* @version V1.0
* @desc Connection 事务管理
* 使用方式:
* (1)首先从TransactionManager获取Connection
* (2)开启事务
* ()进行业务处理
* (3)提交事务
* (4)异常回滚事务
* (5)关闭链接
*/
public final class TransactionManager { /**
* 定义局部线程变量,用于保存Connection
*/
private static final ThreadLocal<Connection> connThreadLocal = new ThreadLocal<Connection>(); private TransactionManager(){} /**
* 采用内部类实现单例
*/
private static class TransactionManagerHolder{
private static final TransactionManager instance = new TransactionManager();
} public static TransactionManager getInstance(){
return TransactionManagerHolder.instance;
} /**
* 1:从当前线程局部变量中获取数据库连接资源
* @return
*/
public Connection get(){
Connection conn = connThreadLocal.get(); if(null==conn){
conn = JdbcUtil.getConnection();
connThreadLocal.set(conn);
} return conn;
} /**
* 2:开启事务
* @param conn
*/
public void beginTransaction(Connection conn){
try {
if(null!=conn){
if(conn.getAutoCommit()){
conn.setAutoCommit(false);
}
}
}catch (SQLException ex) {
Logger.getLogger(TransactionManager.class.getName()).log(Level.SEVERE, null, ex);
} } /**
* 3:提交事务
* @param conn
*/
public void commitTransaction(Connection conn){
try {
if(null!=conn){
if(!conn.getAutoCommit()){
conn.commit();
}
}
}catch (SQLException ex) {
Logger.getLogger(TransactionManager.class.getName()).log(Level.SEVERE, null, ex);
}
} /**
* 4:回滚事务
* @param conn
*/
public void rollbackTransaction(Connection conn){
try {
if(null!=conn){
if(!conn.getAutoCommit()){
conn.rollback();
}
}
}catch (SQLException ex) {
Logger.getLogger(TransactionManager.class.getName()).log(Level.SEVERE, null, ex);
}
} /**
* 5:关闭链接,将数据库连接从当前线程局部变量中移除
* @param conn
*/
public void close(Connection conn){
JdbcUtil.release(conn); connThreadLocal.remove();
} }

测试:

package com.mw.test;

import com.mw.utils.TransactionManager;
import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.SQLException;
import java.sql.Types;
import java.util.List;
import java.util.Map;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.MapHandler;
import org.apache.commons.dbutils.handlers.MapListHandler; /**
* @author y
* @date 2015-4-4 12:34:05
* @version 1.0
* @desc
*/
public class Test { public static void main(String[] args) {
QueryRunner qr = new QueryRunner(); Connection conn = TransactionManager.getInstance().get(); TransactionManager.getInstance().beginTransaction(conn); int age = 10; try {
CallableStatement cs = conn.prepareCall("{call pack_user.p_user_select(?,?)}");
cs.setInt(1, age);
cs.registerOutParameter(2, Types.VARCHAR); cs.execute(); String succ = cs.getString(2); if("T".equalsIgnoreCase(succ)){
String sql = "select * from tmp_yshy"; List<Map<String, Object>> list = qr.query(conn, sql, new MapListHandler()); for(Map map:list){
System.out.println("c1:"+map.get("c1")+",c2:"+map.get("c2"));
}
}else{
System.out.println("succ:"+succ);
} TransactionManager.getInstance().commitTransaction(conn);
} catch (SQLException ex) {
TransactionManager.getInstance().rollbackTransaction(conn);
Logger.getLogger(Test.class.getName()).log(Level.SEVERE, null, ex);
} finally{
TransactionManager.getInstance().close(conn);
} } }

封装JDBC事务操作,执行存储过程测试的更多相关文章

  1. spring jdbc查询 依赖JdbcTemplate这个类模版封装JDBC的操作

    package cn.itcast.spring.jdbc; import java.util.List; import org.springframework.jdbc.core.support.J ...

  2. 网络协议 finally{ return问题 注入问题 jdbc注册驱动问题 PreparedStatement 连接池目的 1.2.1DBCP连接池 C3P0连接池 MYSQL两种方式进行实物管理 JDBC事务 DBUtils事务 ThreadLocal 事务特性 并发访问 隔离级别

    1.1.1 API详解:注册驱动 DriverManager.registerDriver(new com.mysql.jdbc.Driver());不建议使用 原因有2个: >导致驱动被注册2 ...

  3. Mysql事务与JDBC事务管理

    一.事务概述 1.什么是事务 一件事情有n个组成单元 要不这n个组成单元同时成功 要不n个单元就同时失败 就是将n个组成单元放到一个事务中 2.mysql的事务 默认的事务:一条sql语句就是一个事务 ...

  4. Jdbc执行存储过程报数据库事务无法执行的异常

    Jdbc执行存储过程报数据库事务无法执行的异常 环境: Eclipse+Jdk1.7+spring-jdbc-3.0.7+同版本的jdbctemplate+Sqlserver 2012 问题: 一个小 ...

  5. jdbc中的Statement对象和Preparedstatement对象的区别,以及通过jdbc操作调用存储过程

    一. java.sql.*   和  javax.sql.*的包的类结构 |- Driver接口: 表示java驱动程序接口.所有的具体的数据库厂商要来实现此接口. |- connect(url, p ...

  6. MySQL(存储过程,支持事务操作)

    day61 保存在MySQL上的一个别名   >   一坨SQL语句 -- delimiter // -- create procedure p1() -- BEGIN -- select * ...

  7. 一、JDBC的概述 二、通过JDBC实现对数据的CRUD操作 三、封装JDBC访问数据的工具类 四、通过JDBC实现登陆和注册 五、防止SQL注入

    一.JDBC的概述###<1>概念 JDBC:java database connection ,java数据库连接技术 是java内部提供的一套操作数据库的接口(面向接口编程),实现对数 ...

  8. 使用JDBC进行数据库的事务操作(2)

    本篇将讲诉如何使用JDBC进行数据库有关事务的操作.在上一篇博客中已经介绍了事务的概念,和在MySQL命令行窗口进行开启事务,提交事务以及回滚事务的操作. 似乎事务和批处理都可以一次同时执行多条SQL ...

  9. 使用JDBC进行数据库的事务操作(1)

    本篇讲述数据库中非常重要的事务概念和如何使用MySQL命令行窗口来进行数据库的事务操作.下一篇会讲述如何使用JDBC进行数据库的事务操作. 事务是指数据库中的一组逻辑操作,这个操作的特点就是在该组逻辑 ...

随机推荐

  1. PHP PDO 安装使用

    PDO(PHP Data Object) 是PHP 5新出来的东西,在PHP 6都要出来的时候,PHP 6只默认使用PDO来处理数据库,将把所有的数据库扩展移到了PECL,那么默认就是没有了我们喜爱的 ...

  2. 【转】Linux 中断学习之小试牛刀篇

    原文网址:http://www.linuxidc.com/Linux/2011-02/32129.htm 前言 在前面分析了中断的基本原理后,就可以写一个内核中断程序来体验以下,也可以借此程序继续深入 ...

  3. Http请求工具实例编写

    HTTP协议工作方式首先客户端发送一个请求(request)给服务器,服务器在接收到这个请求后将生成一个响应(response)返回给客户端.在这个通信的过程中HTTP协议在以下4个方面做了规定:1. ...

  4. JavaScript……

    退役了好伤心…… 这几天搞研究性学习写网页版贪吃蛇代码……太蛋疼了 要学javascript,就还要搞AJAX.JQuery.JSON…… 我感觉整个人都不好了

  5. android TextView 添加下划线

    android Textview加下划线 由于新做的一个项目要求有字体带下划线效果,当时看了下其实可以通过图片伪造出那种视觉效果.但是为了体现点技术含量,于是我想用Textview带下划线的效果.方法 ...

  6. typedef与define的区别

    1) #define是预处理指令,在编译预处理时进行简单的替换,不作正确性检查,不关含义是否正确照样带入,只有在编译已被展开的源程序时才会发现可能的错误并报错.例如:#define PI 3.1415 ...

  7. JS-Array数组内置对象

    直接上代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <ti ...

  8. JavaScript 类私有方法的实现

    一:将私有方法移出模块,因为模块内部的所有方法都是对外可见的. class Widget { foo (baz) { bar.call(this, baz); } // ... } function ...

  9. windows下配置caffe(环境:win7+vs2013+opencv3.0)

    说明:大部分转载于initialneil的大作Caffe + vs2013 + OpenCV in Windows Tutorial (I) – Setup 准备工作: 1.下载CUDA7.5: ht ...

  10. IT江湖

    我喜欢看武侠电影,尤其的70-80年代的邵氏电影,在这个期间,邵氏公司将金庸和古老很多小说都改拍成了电影,可以说,看这些电影是一种享受,真的! 对于现实中的IT世界,也像是一个江湖,当你掌握了一些技能 ...