mybatis之通过单例模式来管理SqlSessionFactory

来源:互联网 发布:绵阳广电网络宽带 编辑:程序博客网 时间:2024/06/07 01:28

SqlSessionFactory是创建SqlSession的工厂,但是创建过程中需要反复加载全局配置文件,这一点是十分耗时的,为了优化项目,最好通过单例模式来管理它,使它只能创建一个对象,配置文件加载一次就可以了。(在mybatis整合spring之后,最好的方式是把sqlsessionfactory交给spring来做单例管理)
背景:由于创建sqlsessionfactory的过程是重复性的,所以干脆做了一个工具类专门生成sqlsessionfactory

实例说明:

package com.oa.utils;import java.io.IOException;import java.io.Reader;import org.apache.ibatis.io.Resources;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;public class sqlSessionFactoryUtil {    //首先创建静态成员变量sqlSessionFactory,静态变量被所有的对象所共享。    public static SqlSessionFactory sqlSessionFactory = null;    public static SqlSessionFactory getSqlSessionFactory() {        //如果sqlSessionFactory没有被创建就读取全局配置文件,假如已经被创建过了,就使用已经存在的sqlsessionfactory。        //这样就有了单例模式的效果        if(sqlSessionFactory==null){            String resource = "mybatis/SqlMapConfig.xml";            try {                Reader reader = Resources.getResourceAsReader(resource);                sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);            } catch (IOException e) {                // TODO Auto-generated catch block                e.printStackTrace();            }        }        return sqlSessionFactory;    }}
0 0
原创粉丝点击