zoukankan      html  css  js  c++  java
  • MyBatisUtil类

    在用MyBatis框架连接数据库时,往往要经常创建sessionFactory,重复的编写大量代码,故将其中的重复代码提出成一个工具类,这样直接调用方法即可,可简化代码编写和优化运行效率,不需要重复的读取mybatis核心配置文件和反复new工厂对象

    编写的MyBatis的util工具类如下:

    package com.study.util;
     
    import java.io.IOException;
    import java.io.Reader;
     
    import org.apache.ibatis.io.Resources;
    import org.apache.ibatis.session.SqlSession;
    import org.apache.ibatis.session.SqlSessionFactory;
    import org.apache.ibatis.session.SqlSessionFactoryBuilder;
     
    public class MyBatisUtil {
     
        private static SqlSessionFactory sessionFactory = null;
        /*
         * 创建本地线程变量,为每一个线程独立管理一个session对象 每一个线程只有且仅有单独且唯一的一个session对象
         * 加上线程变量对session进行管理,可以保证线程安全,避免多实例同时调用同一个session对象
         * 每一个线程都会new一个线程变量,从而分配到自己的session对象
         */
        private static ThreadLocal<SqlSession> threadlocal = new ThreadLocal<SqlSession>();
     
        // 创建sessionFactory对象,因为整个应用程序只需要一个实例对象,故用静态代码块
        static {
            try {
                Reader reader = Resources.getResourceAsReader("Mybatis_config.xml");
                sessionFactory = new SqlSessionFactoryBuilder().build(reader);
                reader.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
     
        /**
         * 返回sessionFactory对象 工厂对象
         * 
         * @return sessionFactory
         */
        public static SqlSessionFactory getSessionFactory() {
            return sessionFactory;
        }
     
        /**
         * 新建session会话,并把session放在线程变量中
         */
        private static void newSession() {
            // 打开一个session会话
            SqlSession session = sessionFactory.openSession();
            // 将session会话保存在本线程变量中
            threadlocal.set(session);
        }
        
        /**
         * 返回session对象
         * @return session
         */
        public static SqlSession getSession(){
            //优先从线程变量中取session对象
            SqlSession session = threadlocal.get();
            //如果线程变量中的session为null,
            if(session==null){
                //新建session会话,并把session放在线程变量中
                newSession();
                //再次从线程变量中取session对象
                session = threadlocal.get();
            }
            return session;
        }
        
        /**
         * 关闭session对象,并从线程变量中删除
         */
        public static void closeSession(){
            //读取出线程变量中session对象
            SqlSession session = threadlocal.get();
            //如果session对象不为空,关闭sessoin对象,并清空线程变量
            if(session!=null){
                session.close();
                threadlocal.set(null);
            }
        }
        
    }

    其中的Mybatis_config.xml是我的MyBatis的核心配置文件。

    用静态代码块进行创建SqlSessionFactory,只在类加载时创建一次,保证了整个程序运行时只有一个工厂实例。

    用线程变量保存session对象,是为了线程安全着想,这样自己的线程管理自己线程的session,不会出现多实例同时调用同一个session对象,造成数据不准确的情况出现。

    MyBatisUtil.getSession(); 即可获得session对象;

    MyBatisUtil.closeSession();  即可关闭线程对象,务必要在session使用完毕后关闭session。

  • 相关阅读:
    GridView中实现点击某行的任意位置就选中该行
    HtmlEncode、HtmlDecode、UrlEncode、UrlDecode
    Asp.net中从后台中如何获取html控件
    关于IE10出现LinkButton点击无效的解决方案
    【转】关于IE7 z-index问题完美解决方案
    【转】Asp.net中时间格式化的6种方法详细总结
    【转】asp.net Cookie值中文乱码问题解决方法
    asp.net中Cookie的用法【转】
    【转】ASP.NET Cookies简单应用 记住用户名和密码
    ASP.NET Cookie 概述【转】
  • 原文地址:https://www.cnblogs.com/moonsoft/p/10131693.html
Copyright © 2011-2022 走看看