zoukankan      html  css  js  c++  java
  • Mybatis获取Sqlsession的工具类

    package com.jyk.mybatis.util;
    
    import java.io.IOException;
    import java.io.Reader;
    import java.sql.Connection;
    
    import org.apache.ibatis.io.Resources;
    import org.apache.ibatis.session.SqlSession;
    import org.apache.ibatis.session.SqlSessionFactory;
    import org.apache.ibatis.session.SqlSessionFactoryBuilder;
    
    /*
     * MyBatis工具类
     */
    public class MyBatisUtil {
    
        private static ThreadLocal<SqlSession> threadLocal = new
                ThreadLocal<SqlSession>();
        private static SqlSessionFactory sqlSessionFactory;
        
        //静态块加载src目录下的mybatis配置文件
        static{
            try {
                Reader reader = Resources.getResourceAsReader("mybatis.xml");
                sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        
        /*
         * 禁止外界通过new方法创建
         */
        private MyBatisUtil(){}
        
        /*
         * 获取sqlsession
         */
        public static SqlSession getSqlSession()
        {
            //从当前线程中获取sqlSession对象
            SqlSession sqlSession = threadLocal.get();
            
            //判断SqlSession对象是否为空
            if(sqlSession==null)
            {
                //在SqlSessionFactory对象非空的情况下,获取SqlSession对象
                sqlSession = sqlSessionFactory.openSession();
                //将SqlSession对象与当前线程绑定在一起
                threadLocal.set(sqlSession);
            }
            
            return sqlSession;
        }
        
        /*
         * 关闭sqlsession与当前线程分开
         */
        public static void closeSqlSession()
        {
            //从当前线程中获取SqlSession对象
            SqlSession sqlSession = threadLocal.get();
            
            if(sqlSession != null)
            {
                //关闭SqlSession对象
                sqlSession.close();
                //分开当前线程与SqlSession对象的关系,目的是尽早进行垃圾回收
                threadLocal.remove();
            }        
        }
        
        /*
         * 测试方法
         */
        public static void main(String[] args) {
            Connection conn = MyBatisUtil.getSqlSession().getConnection();
            if(conn==null)
            {
                System.out.println("连接为空");
            }
            else
            {
                System.out.println("连接不为空");
            }
        }
    }
    坚持
  • 相关阅读:
    cf1043C. Smallest Word(贪心)
    洛谷P1081 开车旅行(倍增)
    NOI.AC NOIP2018 全国热身赛 第四场
    cf444E. DZY Loves Planting(并查集)
    NOI.AC NOIP模拟赛R3解题报告
    中国第一计算机编程高手横瓜的天才求职之路异常艰辛,天妒奇才呀
    C语言全局未初始化数据段分析
    js问题总结
    ios7新增基础类库以及OC新特性
    jquery.post用法
  • 原文地址:https://www.cnblogs.com/gaoSJ/p/13038602.html
Copyright © 2011-2022 走看看