项目中采用SpringMVC+Mybatis的架构,数据库采用mysql,采用的配置文件为形式为无单独Mybatis配置文件的那一种,套用网上的一句话叫做“spring和MyBatis完美整合,不需要mybatis的配置映射文件”。
我得出的结论有两种可能:
1. mysql表引擎不正确,只有InnoDB可以支持事务
2. 配置文件有问题,SpringMVC在处理注解信息的时候发生的冲突。下面贴出项目中的正确配置
a. web.xml中
<!-- Spring和mybatis的配置文件 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:conf/spring-mybatis.xml</param-value>
</context-param>
<!-- Spring MVC servlet -->
<span style="white-space:pre"> </span><servlet>
<span style="white-space:pre"> </span><servlet-name>SpringMVC</servlet-name>
<span style="white-space:pre"> </span><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<span style="white-space:pre"> </span><init-param>
<span style="white-space:pre"> </span><param-name>contextConfigLocation</param-name>
<span style="white-space:pre"> </span><param-value>classpath:conf/spring-mvc.xml</param-value>
<span style="white-space:pre"> </span></init-param>
<span style="white-space:pre"> </span><load-on-startup>1</load-on-startup>
<span style="white-space:pre"> </span><async-supported>true</async-supported>
<span style="white-space:pre"> </span></servlet>
其中有两个配置文件
b. spring-mybatis.xml 中
<mvc:annotation-driven />
<!-- 自动扫描 -->
<context:component-scan base-package="com.XXX">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
<tx:annotation-driven transaction-manager="transactionManager" />
<tx:annotation-driven transaction-manager="transactionManagerBMS" />
c, spring-mvc.xml 中
<mvc:annotation-driven />
<context:component-scan base-package="com.XXX">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service"/>
</context:component-scan>
配置完成之后,事务就可以生效了