Spring暂未提供整合myBatis的功能,目前只能使用myBatis提供的mybatis-spring整合类包。不过从功能上来说,mybatis-spring完全符合Spring的风格,功能上也没有任何区别。
- <?xml version="1.0" encoding="UTF-8" ?>
- <beans …>
- <beans …>
- <context:component-scan base-package="com.sample.dao.mybatis" />
- <context:component-scan base-package="com.sample.service.mybatis" />
- <context:property-placeholder location="classpath:jdbc.properties" />
- <bean id="dataSource"
- class="org.apache.commons.dbcp.BasicDataSource"
- destroy-method="close"
- p:driverClassName="${jdbc.driverClassName}"
- p:url="${jdbc.url}"
- p:username="${jdbc.username}"
- p:password="${jdbc.password}" />
- <bean id="sqlSessionFactory"
- class="org.mybatis.spring.SqlSessionFactoryBean" ①
- p:dataSource-ref="dataSource"
- p:configLocation="classpath:myBatisConfig.xml"/> ②
- </beans>
mybatis-spring类包提供了一个SqlSessionFactoryBean,以便通过Spring风格创建myBatis的SqlSessioinFactory,如①所示。只需要注入数据源并指定myBatis的总装配置文件就可以了,如②所示。
如果在myBatis总装配置文件mybatisConfig.xml中指定SQL映射文件,必须逐个列表所有的SQL映射文件,比较烦琐。是否可以像Spring加载Hibernate映射文件一样按资源路径匹配规则扫描式加载呢?答案是肯定的,SqlSessionFactoryBean提供了mapperLocations属性,支持扫描式加载SQL映射文件。
先将映射文件匹配从mybatisConfig.xml中移除,然后通过如下便捷的方式加载SQL映射文件:
- <bean id="sqlSessionFactory"
- class="org.mybatis.spring.SqlSessionFactoryBean"
- p:dataSource-ref="dataSource"
- p:configLocation="classpath:myBatisConfig.xml"
- p:mapperLocations="classpath:com/sample/domain/mybatis/*.xml"/>
这样,SqlSessionFactoryBean将扫描com/sample/domain/mybatis类路径并加载所有以xml为后缀的映射文件。