注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

北漂的小羊

Java编程,开发者,程序员,软件开发,编程,代码。新浪微博号:IT国子监

 
 
 

日志

 
 
关于我

在这里是面向程序员的高品质IT技术学习社区,是程序员学习成长的地方。让我们更好地用技术改变世界。请关注新浪微博号: IT国子监(http://weibo.com/itguozijian)

网易考拉推荐

如何在JDBC+servlet的项目中使用事务  

2011-05-26 15:29:33|  分类: JAVA |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

事务: 说白了就是在一个connection里面做了一堆的事情, 在特定的时间点 [完成,异常] 进行提交或回滚. 

所以, 无论是否Spring的TransactionManager还是自己的Servlet上的事务控制, 都是基于在一个事务单元内的一个connection上的, 所以, 你要将connection绑定在一个ThreadLocal上, 让里面所有的jdbc操作使用这个connection就好, 在Servlet的所有jdbc操作完成后, 再进行显示的commit 或 rollback. 


下面的代码随手写的, 只是用于说明问题. 

SessionConnectionUtil {  
  
static ThreadLocal holder = new ThreadLocal();  
  
public static getConnection() {  
    if (holder.get() == null) {  
        holder.sut(new Connection());  
    }  
   return (Connection) holder.get();  
}  
  
public static closeConnection() {  
   holder.set(null);  
}  
  
}  
  
  
CustomServlet extends HttpServlet {  
   CustomDao dao;  
   service() {  
        try {  
            dao.doSomething();  
  
        SessionConnectionUtil.getConnection().commit();  
    } catch (Exception e) {  
            SessionConnectionUtil.getConnection().rollback();  
    } finally {  
        SessionConnectionUtil.closeConnection();  
    }  
   }  
}  
  
CustomDao {  
   doSomething() {  
       Connection connection = SessionConnectionUtil.getConnection();  
       ...  
   }  
}  
  评论这张
 
阅读(188)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2016