<转>myBatis-spring整合之sqlsessionfactory
2016-08-09 10:58
295 查看
在基本的MyBatis中,session工厂可以使用SqlSessionFactoryBuilder来创建。在MyBatis-Spring中,使用SqlSessionFactoryBean来替代。
SqlSessionFactoryBean实现了spring的FactoryBean接口。这就说明由spring最终创建的bean不是 SqlSessionFactoryBean本身,而是工厂类的getObject()返回的方法结果。这种情况下,spring将会在应用启动时为你创 建SqlSessionFactory对象,然后将它以SqlSessionFactory为名来存储。
在一般的MyBatis-spring用法中,你不需要直接使用SqlSessionFactoryBean或其对应的 SqlSessionFactory。相反,session工厂将会被注入到MapperFactoryBean或其它扩展了 SqlSessionDaoSupport的DAO中。
属性
SqlSessionFactory有一个单独的必须属性,就是JDBC的DataSource。这可以是任意的DataSource。其配置应该和其它spring数据库连接是一样的。
一个通用的属性是configLocation,它是用来指定MyBatis的xml配置文件路径的。 如果基本的MyBatis配置需要改变,那么这就是一个需要它的地方。通常这会是<settings> 或<typeAliases>的部分。要注意这个配置文件不需要是一个完整的MyBatis配置。确定地说,任意环境,数据源和 myBatis的事务管理器都会被忽略。SqlSessionFactoryBean会创建它自己的,使用这些值定制MyBatis的
Environment时是需要的。
如果myBatis映射器xml文件在和映射器类相同的路径下不存在,那么另外一个需要配置文件的原因就是它了。使用这个配置,有两种选择。第一是手动在myBatis的xml配置文件中使用<mappers>部分来指定类路径。第二是使用工厂bean的mapperLocations属性。mapperLocations属性使用一个资源位置的list。这个属性可以用来指定myBatis的xml映射器文件的位置。如:
Java代码
![](http://fhd001.iteye.com/images/icon_star.png)
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="configLocation" value="classpath:mybatis.xml" />
<property name="mapperLocations" value="classpath:mapper/**/*.xml" />
</bean>
在容器环境管理事务中,一个可能需要的属性是transactionFactoryClass。
SqlSessionFactoryBean实现了spring的FactoryBean接口。这就说明由spring最终创建的bean不是 SqlSessionFactoryBean本身,而是工厂类的getObject()返回的方法结果。这种情况下,spring将会在应用启动时为你创 建SqlSessionFactory对象,然后将它以SqlSessionFactory为名来存储。
在一般的MyBatis-spring用法中,你不需要直接使用SqlSessionFactoryBean或其对应的 SqlSessionFactory。相反,session工厂将会被注入到MapperFactoryBean或其它扩展了 SqlSessionDaoSupport的DAO中。
属性
SqlSessionFactory有一个单独的必须属性,就是JDBC的DataSource。这可以是任意的DataSource。其配置应该和其它spring数据库连接是一样的。
一个通用的属性是configLocation,它是用来指定MyBatis的xml配置文件路径的。 如果基本的MyBatis配置需要改变,那么这就是一个需要它的地方。通常这会是<settings> 或<typeAliases>的部分。要注意这个配置文件不需要是一个完整的MyBatis配置。确定地说,任意环境,数据源和 myBatis的事务管理器都会被忽略。SqlSessionFactoryBean会创建它自己的,使用这些值定制MyBatis的
Environment时是需要的。
如果myBatis映射器xml文件在和映射器类相同的路径下不存在,那么另外一个需要配置文件的原因就是它了。使用这个配置,有两种选择。第一是手动在myBatis的xml配置文件中使用<mappers>部分来指定类路径。第二是使用工厂bean的mapperLocations属性。mapperLocations属性使用一个资源位置的list。这个属性可以用来指定myBatis的xml映射器文件的位置。如:
Java代码
![](http://fhd001.iteye.com/images/icon_star.png)
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="configLocation" value="classpath:mybatis.xml" />
<property name="mapperLocations" value="classpath:mapper/**/*.xml" />
</bean>
在容器环境管理事务中,一个可能需要的属性是transactionFactoryClass。
相关文章推荐
- MyBatis整合Spring-->SqlSession获取
- Mybatis与Spring整合(Mybatis的sqlSessionFactory交由spring容器来创建)
- Spring、MyBatis的整合数据映射器类(UserMapper->iocContext.xml)配置文件详解
- 整合springmvc+mybatis+veloctiy<二>
- 项目SpringMVC+Spring+Mybatis 整合环境搭建(2)-> 测试Spring+Mybatis 环境
- Spring与mybatis的整合实践之SqlSessionTemplate持久化模板详解
- Spring3 整合MyBatis3 配置多数据源 动态选择SqlSessionFactory
- Spring与mybatis的整合实践之SqlSessionTemplate持久化模板
- Mybatis整合spring的时候用log4j输出sql信息的debug设置
- Spring3 整合MyBatis3 配置多数据源 动态选择SqlSessionFactory
- Spring3 整合MyBatis3 配置多数据源 动态选择SqlSessionFactory
- Spring3 整合MyBatis3 配置多数据源 动态选择SqlSessionFactory
- Spring3 整合MyBatis3 配置多数据源 动态选择SqlSessionFactory
- Spring3 整合MyBatis3 配置多数据源 动态选择SqlSessionFactory
- <转>最新版的SSH框整合(Spring 3.1.1 + Struts 2.3.1.2 + Hibernate 4.1)
- 整理springmvc+mybatis+velocity的整合<一>
- Spring3 整合MyBatis3 配置多数据源 动态切换 选择SqlSessionFactory
- javaWeb项目SpringMVC3.2.1与Mybatis3.0.4整合实例(Mybaits-spring配置文件的几种方式)之一SqlSessionDaoSupport方式
- mybatis 整合spring mv SqlSessionDaoSupport
- Spring3 整合MyBatis3 配置多数据源 动态选择SqlSessionFactory