MyBatis Spring整合配置映射接口類與映射xml文件

spring整合MyBatis使用到了mybatis-spring,在配置mybatis映射文件的時候,一般會使用MapperScannerConfigurer,MapperScannerConfigurer會自動掃描basePackage指定的包,找到映射接口類和映射XML文件,並進行注入。配置如下:

[html] view plain copy
  1. <!-- 數據源 -->  
  2. <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">  
  3.     <property name="driverClass" value="${${database.type}.jdbc.driverClassName}"/>  
  4.     <property name="jdbcUrl" value="${${database.type}.jdbc.url}"/>  
  5.     <property name="properties" ref="dataSourceProperties"/>  
  6.     <property name="autoCommitOnClose" value="true"/>  
  7.     <property name="checkoutTimeout" value="${cpool.checkoutTimeout}"/>  
  8.     <property name="initialPoolSize" value="${cpool.minPoolSize}"/>  
  9.     <property name="minPoolSize" value="${cpool.minPoolSize}"/>  
  10.     <property name="maxPoolSize" value="${cpool.maxPoolSize}"/>  
  11.     <property name="maxIdleTime" value="${cpool.maxIdleTime}"/>  
  12.     <property name="acquireIncrement" value="${cpool.acquireIncrement}"/>  
  13.     <property name="maxIdleTimeExcessConnections" value="${cpool.maxIdleTimeExcessConnections}"/>  
  14. </bean>  
  15.   
  16. <!--基於註解的事務管理-->  
  17. <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
  18.     <property name="dataSource" ref="dataSource"/>  
  19. </bean>  
  20.   
  21. <tx:annotation-driven transaction-manager="transactionManager"/>  
  22.   
  23.   
  24. <bean id="lazySqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
  25.     <property name="dataSource" ref="dataSource"/>  
  26.     <property name="configLocation" value="classpath:mybatis/mybatis-config.xml"/>  
  27. </bean>  
  28.   
  29. <!-- 掃描mybatis映射接口類  ****重點配置****-->  
  30. <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">  
  31.     <property name="basePackage" value="com.test.dsm"/>  
  32.     <property name="sqlSessionFactoryBeanName" value="lazySqlSessionFactory"/>  
  33. </bean>  
這個配置的前提條件是:映射接口類文件(.java)和映射XML文件(.xml)需要放在相同的包下(com.test.dsm)


如果myBatis映射XML文件和映射接口文件不放在同一個包下怎麼辦呢?

如果在不同的包下,那就需要手動配置XML文件的路徑了,只需要修改SqlSessionFactoryBean配置即可:

[html] view plain copy
  1. <bean id="lazySqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
  2.     <property name="dataSource" ref="dataSource"/>  
  3.     <property name="configLocation" value="classpath:mybatis/mybatis-config.xml"/>  
  4.     <!-- 當mybatis的xml文件和mapper接口不在相同包下時,需要用mapperLocations屬性指定xml文件的路徑。  
  5.          *是個通配符,代表所有的文件,**代表所有目錄下 -->  
  6.     <property name="mapperLocations" value="classpath:com/test/mapper/mysql/**/*.xml" />  
  7. </bean>  

添加一個mapperLocations屬性,指定加載xml文件的路徑。

classpath:表示在classes目錄中查找;

*:通配符表示所有文件;

**:表示所有目錄下;


MyBatis官網說明如下:http://mybatis.github.io/spring/factorybean.html

發佈了14 篇原創文章 · 獲贊 5 · 訪問量 4萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章