码迷,mamicode.com
首页 > 其他好文 > 详细

利用ThreadLocal管理事务

时间:2018-02-05 23:28:15      阅读:170      评论:0      收藏:0      [点我收藏+]

标签:exception   class   new   except   remove   .com   com   pos   int   

package com.itheima.util;

import java.sql.Connection;
import java.sql.SQLException;
//封装了所有与事务有关的方法
public class TransactionManager {
    private static ThreadLocal<Connection> tl = new ThreadLocal<Connection>();
    public static Connection getConnection(){
        Connection conn = tl.get();
        if(conn==null){//从当前线程中获取链接
            conn = DBCPUtil.getConnection();
            tl.set(conn);
        }
        return conn;
    }
    public static void startTransaction(){
        try {
            Connection conn = getConnection();
            conn.setAutoCommit(false);
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
    public static void rollback(){
        try {
            Connection conn = getConnection();
            conn.rollback();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
    public static void commit(){
        try {
            Connection conn = getConnection();
            conn.commit();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
    public static void release(){
        try {
            Connection conn = getConnection();
            conn.close();
            tl.remove();//从当前线程中解绑。  与服务器实现有关:服务器采用线程池。
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

 

利用ThreadLocal管理事务

标签:exception   class   new   except   remove   .com   com   pos   int   

原文地址:https://www.cnblogs.com/xiarongjin/p/8419353.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!