MyBatis的SqlSessionFactory的创建问题

<!-- @page { margin: 0.79in } P { margin-bottom: 0.08in } -->

 

MyBatis文档中,提到SqlSessionFactory最好在程序中只被创建一次。建议使用Singleton或者SpringGuicedependency injection框架。

Spring中使用MyBatis完全可以采用Spring-mybatis,无须考虑factory的生命周期。

本文考虑自己实现Singleton机制。选用之前我的Singleton文章中提到的第四种Singleton实现方案,lazy loading模式。

 

大体思路:

实现一个Holder类,该类是Singleton的,将SqlSessionFactory作为该类的成员变量。Holder类的构造函数只会被调用一次,并且会将SqlSessionFactory实例化。以后每次调用Holder.getFactory()方法就能获得同一个SqlSessionFactory对象。不过由于我还没有找到支持创建时参数的方案,使用另一个Singleton对象Configuration作为依赖。

 

使用代码如下:

 

Configuration.getInstance().setXmlPath("com/lifeix/mybatis/xml/dbConfig.xml");

SqlSessionFactorySingletonHolder factoryHolder = SqlSessionFactorySingletonHolder.getInstance();

SqlSession session = factoryHolder.getFactory().openSession();

 

 

Configuration类代码如下:

 

public class Configuration { private static class SingletonHolder{ private static final Configuration INSTANCE = new Configuration(); } public static Configuration getInstance(){ return SingletonHolder.INSTANCE; } private Configuration() { } @Getter @Setter private String xmlPath; } 

SqlSessionFactorySingletonHodler类的代码如下:

 

import lombok.Getter; 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; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class SqlSessionFactorySingletonHolder { static class InnerHolder{ private static final SqlSessionFactorySingletonHolder INSTANCE; static { try { INSTANCE = new SqlSessionFactorySingletonHolder(); } catch (Exception e) { throw new ExceptionInInitializerError(e); } } } public static SqlSessionFactorySingletonHolder getInstance(){ return InnerHolder.INSTANCE; } private SqlSessionFactorySingletonHolder() throws Exception { init(); } private void init() throws Exception { log = LoggerFactory.getLogger(getClass()); Reader reader = null; try { reader = Resources.getResourceAsReader(Configuration.getInstance().getXmlPath()); factory = new SqlSessionFactoryBuilder().build(reader); }catch(Exception ex){ log.error(ex.getMessage(),ex); throw ex; } finally { try { if(reader != null){ reader.close(); } } catch (IOException ex) { log.error(ex.getMessage(),ex); } } } @Getter private SqlSessionFactory factory; private Logger log; } 

 

 

希望对不使用Spring等框架的人有帮助。

 

 

转载于:https://www.cnblogs.com/believeit/archive/2011/05/07/2183540.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值