封装JDBC事务操作,执行存储过程测试
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事务操作,执行存储过程测试的更多相关文章
- spring jdbc查询  依赖JdbcTemplate这个类模版封装JDBC的操作
		package cn.itcast.spring.jdbc; import java.util.List; import org.springframework.jdbc.core.support.J ... 
- 网络协议 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 ... 
- Mysql事务与JDBC事务管理
		一.事务概述 1.什么是事务 一件事情有n个组成单元 要不这n个组成单元同时成功 要不n个单元就同时失败 就是将n个组成单元放到一个事务中 2.mysql的事务 默认的事务:一条sql语句就是一个事务 ... 
- Jdbc执行存储过程报数据库事务无法执行的异常
		Jdbc执行存储过程报数据库事务无法执行的异常 环境: Eclipse+Jdk1.7+spring-jdbc-3.0.7+同版本的jdbctemplate+Sqlserver 2012 问题: 一个小 ... 
- jdbc中的Statement对象和Preparedstatement对象的区别,以及通过jdbc操作调用存储过程
		一. java.sql.* 和 javax.sql.*的包的类结构 |- Driver接口: 表示java驱动程序接口.所有的具体的数据库厂商要来实现此接口. |- connect(url, p ... 
- MySQL(存储过程,支持事务操作)
		day61 保存在MySQL上的一个别名 > 一坨SQL语句 -- delimiter // -- create procedure p1() -- BEGIN -- select * ... 
- 一、JDBC的概述 	二、通过JDBC实现对数据的CRUD操作 	三、封装JDBC访问数据的工具类 	四、通过JDBC实现登陆和注册 	五、防止SQL注入
		一.JDBC的概述###<1>概念 JDBC:java database connection ,java数据库连接技术 是java内部提供的一套操作数据库的接口(面向接口编程),实现对数 ... 
- 使用JDBC进行数据库的事务操作(2)
		本篇将讲诉如何使用JDBC进行数据库有关事务的操作.在上一篇博客中已经介绍了事务的概念,和在MySQL命令行窗口进行开启事务,提交事务以及回滚事务的操作. 似乎事务和批处理都可以一次同时执行多条SQL ... 
- 使用JDBC进行数据库的事务操作(1)
		本篇讲述数据库中非常重要的事务概念和如何使用MySQL命令行窗口来进行数据库的事务操作.下一篇会讲述如何使用JDBC进行数据库的事务操作. 事务是指数据库中的一组逻辑操作,这个操作的特点就是在该组逻辑 ... 
随机推荐
- sybase 备份和恢复
			use master go dump transaction MBFEWKDB with no_log go dump transaction MBFEHISDB with no_log go use ... 
- 【转】secureCRT使用退格键(backspace)出现^H解决办法
			原文网址:http://skykiss.blog.51cto.com/blog/2892603/769771 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将 ... 
- poj2955:括号匹配,区间dp
			题目大意: 给一个由,(,),[,]组成的字符串,其中(),[]可以匹配,求最大匹配数 题解:区间dp: dp[i][j]表示区间 [i,j]中的最大匹配数 初始状态 dp[i][i+1]=(i,i+ ... 
- linux下的java远程调试jpda+tomcat
			项目放到linux服务器了,服务器的环境或者数据可能和我们本地不一样,这个时候我们可能需要远程的断点进行调试,来查看请求过程中的各个变量的值.这里我们的应用服务器用的tomcat5.5.17 这个时候 ... 
- 【转】在ASP.NET MVC中,使用Bundle来打包压缩js和css
			在ASP.NET MVC4中(在WebForm中应该也有),有一个叫做Bundle的东西,它用来将js和css进行压缩(多个文件可以打包成一个文件),并且可以区分调试和非调试,在调试时不进行压缩,以原 ... 
- SWFLoader交互
			主应用程序: <?xml version="1.0" encoding="utf-8"?> <s:Application xmlns:fx=& ... 
- __device__ __global__ __host__
			__device__ 标记的函数从一个在器件中执行的函数呼叫,在器件中执行 __global__ 表示该函数从一个在主机中执行的函数呼叫,在器件中执行 __host__表示在主机中呼叫,在主机中执行的 ... 
- ACdream 1417 Numbers
			pid=1417">题目链接~~> 做题感悟:比赛的时候用的广搜,然后高高兴兴的写完果断TLE .做题的时候不管什么题都要用笔画一下,模拟几组数据,这样或许就AC了(做题经验,有 ... 
- 命令行运行android模拟器
			创建模拟器 android create avd --name avd_4.1 --target "android-16" --abi armeabi-v7a Android 4. ... 
- easyui-form添加自定义表单验证
			easyui自定义表单验证规则其实不是很复杂,只要重写一下重写 $.fn.validatebox.defaults.rules 自定义示例 $.extend($.fn.validatebox.defa ... 
