Bootstrap

模块化开发的时候,sqlsession如何配置多个typeAliasesPackage,mapperLocations

如图,我们进行模块化开发的时候,往往我们每个人的bean和mapper都不在同一个路径包内,



如果我们按照以下方式配置的话,就会报异常,大致上是因为不支持
<!-- 通过工厂创建 session -->
    <bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
        <!-- 使用构造方法进行di -->
        <constructor-arg index="0" ref="sqlSessionFactory" />
    </bean>

<!-- mybatis的会话工厂,主要完成读取mybatis的配置文件的工作 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!-- 数据源 -->
        <property name="dataSource" ref="dataSource" />

        <!-- 包别名,设置了这个在映射文件mapper中的对应的类名就不需要写全称了 -->
        <property name="typeAliasesPackage" value="com/yc*bean" />

        <!-- 映射文件的路径 -->
        <property name="mapperLocations" value="classpath*:com/yc*bean/*.xml" />

     
        <!-- 主要用来配置mybatis中的 configuration中的settings配置 -->
        <property name="configurationProperties">
            <props>
                <prop key="logImpl">LOG4J</prop>
            </props>
        </property>
    </bean>
部分异常如下:
org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.exceptions.PersistenceException:
### Error querying database.  Cause: java.lang.IllegalArgumentException: Mapped Statements collection does not contain value for com.yc.ssq.bean.UserSsqMapper.findAfterBuy
### Cause: java.lang.IllegalArgumentException: Mapped Statements collection does not contain value for com.yc.ssq.bean.UserSsqMapper.findAfterBuy
    at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:79)
    at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:447)
    at $Proxy21.selectList(Unknown Source)
... ...
这时候,我们就需要配置多个typeAliasesPackage,mapperLocations,
在typeAliasesPackage里,每个包用 ; 隔开
在mapperLocations中,每个*mapper.xml 可以按照以下配置

<!-- mybatis的会话工厂,主要完成读取mybatis的配置文件的工作 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!-- 数据源 -->
        <property name="dataSource" ref="dataSource" />

        <!-- 包别名,设置了这个在映射文件mapper中的对应的类名就不需要写全称了 -->
        <property name="typeAliasesPackage" value="com/yc/ssq/bean;com/yc/soccer/bean" />

        <!-- 映射文件的路径 -->
        <!-- <property name="mapperLocations" value="classpath*:com/yc/ssq/bean/*.xml" /> -->
        <property name="mapperLocations">
            <array>
                <value>classpath*:com/yc/ssq/bean/*.xml</value>
                <value>classpath*:com/yc/soccer/bean/*.xml</value>
            </array>
        </property>


        <!-- 主要用来配置mybatis中的 configuration中的settings配置 -->
        <property name="configurationProperties">
            <props>
                <prop key="logImpl">LOG4J</prop>
            </props>
        </property>
    </bean>

然后通过测试,就知道可以模块化分工合作了

;