spring整合MyBatis使用到了mybatis-spring,在配置mybatis映射文件的時候,一般會使用MapperScannerConfigurer,MapperScannerConfigurer會自動掃描basePackage指定的包,找到映射接口類和映射XML文件,並進行注入。配置如下:
- <!-- 數據源 -->
- <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
- <property name="driverClass" value="${${database.type}.jdbc.driverClassName}"/>
- <property name="jdbcUrl" value="${${database.type}.jdbc.url}"/>
- <property name="properties" ref="dataSourceProperties"/>
- <property name="autoCommitOnClose" value="true"/>
- <property name="checkoutTimeout" value="${cpool.checkoutTimeout}"/>
- <property name="initialPoolSize" value="${cpool.minPoolSize}"/>
- <property name="minPoolSize" value="${cpool.minPoolSize}"/>
- <property name="maxPoolSize" value="${cpool.maxPoolSize}"/>
- <property name="maxIdleTime" value="${cpool.maxIdleTime}"/>
- <property name="acquireIncrement" value="${cpool.acquireIncrement}"/>
- <property name="maxIdleTimeExcessConnections" value="${cpool.maxIdleTimeExcessConnections}"/>
- </bean>
- <!--基於註解的事務管理-->
- <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
- <property name="dataSource" ref="dataSource"/>
- </bean>
- <tx:annotation-driven transaction-manager="transactionManager"/>
- <bean id="lazySqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
- <property name="dataSource" ref="dataSource"/>
- <property name="configLocation" value="classpath:mybatis/mybatis-config.xml"/>
- </bean>
- <!-- 掃描mybatis映射接口類 ****重點配置****-->
- <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
- <property name="basePackage" value="com.test.dsm"/>
- <property name="sqlSessionFactoryBeanName" value="lazySqlSessionFactory"/>
- </bean>
如果myBatis映射XML文件和映射接口文件不放在同一個包下怎麼辦呢?
如果在不同的包下,那就需要手動配置XML文件的路徑了,只需要修改SqlSessionFactoryBean配置即可:
- <bean id="lazySqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
- <property name="dataSource" ref="dataSource"/>
- <property name="configLocation" value="classpath:mybatis/mybatis-config.xml"/>
- <!-- 當mybatis的xml文件和mapper接口不在相同包下時,需要用mapperLocations屬性指定xml文件的路徑。
- *是個通配符,代表所有的文件,**代表所有目錄下 -->
- <property name="mapperLocations" value="classpath:com/test/mapper/mysql/**/*.xml" />
- </bean>
添加一個mapperLocations屬性,指定加載xml文件的路徑。
classpath:表示在classes目錄中查找;
*:通配符表示所有文件;
**:表示所有目錄下;
MyBatis官網說明如下:http://mybatis.github.io/spring/factorybean.html