问题描述
在SSM项目中,对于事务管理的常规做法是通过spring中的DataSourceTransactionManager进行事务管理,实现自动提交和异常回滚。
在一个项目的spring配置文件中,发现事务管理配置的切点路径配置不正确,项目中也没有进行显示的事务提交;但是执行DML语句后,数据却实现了更新,到底是什么进行了自动提交的操作呢?
问题排查
1、首先项目配置如下,可以清晰的看到切点的路径不存在,编辑器已经在提示报错。
2、将spring事务管理模块注释掉,发现数据库操作依然正常运行,每次执行sql后,就会自动提交。
3、mybatis如果不进行配置或显示的提交,默认是不自动提交的;spring的事务管理都没有配置,自然也没有进行工作;数据库连接池c3p0也没有进行这方面的操作;经过多方查找,终于发现是mybatis-spring.jar进行了自动提交操作:无论 JDBC 连接是否设置为自动提交,调用 SqlSession 数据方法或在 Spring 事务之外调用任何在映射器中方法,事务都将会自动被提交。官方文档截图如下: