MyBatis-Spring配置

SqlSessionFactoryBean

sqlSessionFactory 即会话工厂。

在MyBatis中, 通过mybatis环境等配置信息构造SqlSessionFactorysqlSessionFactory可以使用 SqlSessionFactoryBuilder 来创建。

//会话工厂
	private SqlSessionFactory sqlSessionFactory;

	@Before
	public void createSqlSessionFactory() throws IOException {
		// 配置文件
		String resource = "SqlMapConfig.xml";
		InputStream inputStream = Resources.getResourceAsStream(resource);
		// 使用SqlSessionFactoryBuilder从xml配置文件中创建SqlSessionFactory
		sqlSessionFactory = new SqlSessionFactoryBuilder()
				.build(inputStream);
而在 MyBatis-Spring 中,则使用 SqlSessionFactoryBean 来替代。

创建工厂bean,放在spring的配置文件中

	<!-- sessionFactory 将spring和mybatis整合 -->  
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
        <property name="dataSource" ref="dataSource" />  
        <property name="configLocation" value="classpath:SqlMapConfig.xml" />  
        <property name="mapperLocations" value="classpath*:mybatis/mapping/**/*.xml" />  
    </bean>  
可以打开SqlSessionFactoryBean类可以发现:

这里的SqlSessionFactoryBean 实现了 Spring 的 FactoryBean 接口,这就说明了由 Spring 最终创建的 bean 不是 SqlSessionFactoryBean 本身, 。 而是工厂类的 getObject()返回的方法的结果。这种情况下,Spring 将会在应用启动时为你 创建 SqlSessionFactory 对象,然后将它以 SqlSessionFactory 为名来存储。

配置里有三个属性:

1.dataSource:必须的属性,数据源,访问数据库的配置属性。

2.configLocation:指定MyBatis的Xml配置文件,通常配置<settings> 或<typeAliases>这些属性。

3.mapperLocation:如果MyBatis映射器XML的路径和映射器接口的路径不一样,需要配置这个属性,这个属性指定MyBatis映射器XML的路径,图中示例就是从mybatis/mapping下和它子文件目录下的Xml都检索出来。 如果在MyBatis的XML中通过<mappers>指定映射器XML的话,这个属性可以不配置。

MapperScannerConfigurer

我们先了解MapperFactoryBean。 MapperFactoryBean的出现为了代替手工使用SqlSessionDaoSupport或SqlSessionTemplate编写数据访问对象(DAO)的代码,使用动态代理实现。

官网关于MapperFactoryBean的配置

<bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
  <property name="mapperInterface" value="org.mybatis.spring.sample.mapper.UserMapper" />
  <property name="sqlSessionFactory" ref="sqlSessionFactory" />
</bean> 
</bean>org.mybatis.spring.sample.mapper.UserMapper是一个映射器接口,我们创建一个MapperFactoryBean实例,然后注入这个接口和sqlSessionFactory(mybatis中提供的SqlSessionFactory接口,MapperFactoryBean会使用SqlSessionFactory创建SqlSession)之后想使用这个UserMapper接口的话,直接通过spring注入这个bean,然后就可以直接使用了,spring内部会创建一个这个接口的动态代理。这是配置一个接口的示例,但是如果我们的项目需要配置多个接口的话,一个一个配会非常麻烦,于是mybatis-spring提供了MapperScannerConfigurer这个类,类下有一个basePackage属性,它将会查找类路径下的映射器并自动将它们创建成MapperFactoryBean。

    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">  
        <property name="basePackage" value="com.ml.data.dao.mapper" />  
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />  
    </bean>
这段配置会扫描com.ml.data.dao.mapper下的所有接口,然后创建各自接口的动态代理类。




  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值