SpringMVC+Mybatis 事务不生效的解决方案
2016-07-12 23:57
471 查看
项目中采用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>
其中有两个配置文件
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>
配置完成之后,事务就可以生效了
我得出的结论有两种可能:
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>
配置完成之后,事务就可以生效了
相关文章推荐
- SQL Server误区30日谈 第1天 正在运行的事务在服务器故障转移后继续执行
- 浅析SQL Server中包含事务的存储过程
- Mysql中的事务是什么如何使用
- MySql的事务使用与示例详解
- C#分布式事务的超时处理实例分析
- C#中的事务用法实例分析
- SQL Server的事务操作隔离模式介绍
- MySQL中事务概念的简洁学习教程
- C#处理Access中事务的方法
- 在ASP.NET 2.0中操作数据之六十一:在事务里对数据库修改进行封装
- oracle 合并查询 事务 sql函数小知识学习
- 深入理解Java事务的原理与应用
- Mybatis传递多个参数的解决办法(三种)
- 获取Java的MyBatis框架项目中的SqlSession的方法
- Mybatis逆工程jar包的修改和打包
- 深入浅析mybatis oracle BLOB类型字段保存与读取
- MyBatis MapperProvider MessageFormat拼接批量SQL语句执行报错的原因分析及解决办法
- sql不常用函数总结以及事务,增加,删除触发器
- MyBatis启动时控制台无限输出日志的原因及解决办法
- 详解Java的MyBatis框架和Spring框架的整合运用