SSM框架事务回滚失效

使用SSM框架进行项目开发时,经常因为配置的问题,可能会遇到一些稀奇古怪的问题,比如说:明明已经配置了事务管理,并且也在需要进行事务控制的方法上添加了@Transactional注解,服务也基本能够正常启动和使用,但是当事务控制的方法中出错时,之前执行的修改数据库的操作,没有被回滚。

另外事务控制失效的另一个明显表现就是任何一个改变数据库数据的操作,都会直接被提交,即操作一经执行,就可以立马在数据库中得以体现。

事务控制未生效的配置。

springmvc配置文件指定扫包路径

<context:component-scan base-package="com.alex">   #错误配置方式

spirng-mybatis配置文件

# 没有引入扫包规则

<!-- 引入数据库配置文件 -->
    <bean id="propertyConfigurer"
        class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="location" value="classpath:jdbc.properties" />
    </bean>

    <!-- 数据库配置 -->
    <bean id="dataSource" class="com.alex.common.tools.DBConnection"
        destroy-method="close">
        <property name="driverClassName" value="${driver}" />
        <property name="url" value="${url}" />
        <property name="username" value="${username}" />
        <property name="password" value="${password}" />
        <!-- 初始化连接大小 -->
        <property name="initialSize" value="${initialSize}"></property>
        <!-- 连接池最大数量 -->
        <property name="maxActive" value="${maxActive}"></property>
        <!-- 连接池最大空闲 -->
        <property name="maxIdle" value="${maxIdle}"></property>
        <!-- 连接池最小空闲 -->
        <property name="minIdle" value="${minIdle}"></property>
        <!-- 获取连接最大等待时间 -->
        <property name="maxWait" value="${maxWait}"></property>
    </bean>

    <!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <!--引入mybatis-config.xml-->
        <property name="configLocation" value="classpath:mybatis-config.xml"/>
        <!-- 自动扫描mapping.xml文件 -->
        <property name="mapperLocations" value="classpath*:com/alex/ai/nlpc/mapper/*/*.xml"></property>
    </bean>

    <!-- DAO接口所在包名,Spring会自动查找其下的类 -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <!--basePackage指定要扫描的包,在此包之下的映射器都会被搜索到。 可指定多个包,包与包之间用逗号或分号分隔 -->
        <property name="basePackage" value="com.alex.ai.nlpc.dao" />
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
    </bean>

    <!-- (事务管理)transaction manager, use JtaTransactionManager for global tx -->
    <bean id="transactionManager"
        class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource" />
    </bean>

    <!-- 配置基于注解的申明式事务 -->
    <tx:annotation-driven transaction-manager="transactionManager"/>

问题分析

其实这并不是我们事务配置的问题,而是我们定义<context:component-scan base-package="包路径">扫包规则的问题,在spirngmvc配置文件中,我们扫描了所有的ben文件,但是我们是使用spring进行事务管理的。但是我们的spring-mybatis配置文件中并没有配置扫包规则。

配置文件不同,管理域也是不一样的,在springmvc配置了扫描所有bean文件,虽然其中包含了springmvc管理的,也包含了spring管理的,但是我们的spring-mybatis文件中并没有扫描和管理spring的配置,所以,spring-mybatis配置文件并不能访问到springmvc中的spring管理。因此,即使配置了事务注解,也不会被spring管理,从而造成了出错了也不会对事务进行回滚。

问题处理

修改方式,让springmvc配置文件只扫描controller目录,并在spring-mybatis文件中,添加扫描和管理spring的配置。
修改后:
springmvc配置
<context:component-scan base-package="com.alex.controller">

spring-mybatis配置文件中添加
<context:component-scan base-package="com.alex.service">
因为我们通常都是在service层进行数据库的操作和控制事务,如果不是在service层进行处理,只需要将package路径修改到需要使用事务的包的路径即可。

亲测,重启运行后,事务控制的方法中出错后,事务正常回滚!

如果一个方法添加了事务控制,那么这个方法中的任何SQL操作,都不会立马对数据库的数据进行修改,而是当这个方法执行结束之后,这些对数据库修改的操作才会被提交。因此我们判断事务是否生效,并不需要执行到有错误出现,只需要观察事务控制方法内的一个SQL执行之后,数据库数据是否立马发生了改变,改变了即说明事务控制没有生效,反之即表示事务控制生效了!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 157,298评论 4 360
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,701评论 1 290
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 107,078评论 0 237
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,687评论 0 202
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,018评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,410评论 1 211
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,729评论 2 310
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,412评论 0 194
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,124评论 1 239
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,379评论 2 242
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,903评论 1 257
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,268评论 2 251
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,894评论 3 233
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,014评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,770评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,435评论 2 269
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,312评论 2 260

推荐阅读更多精彩内容

  • SSM框架整合 SSM(Spring+SpringMVC+MyBatis)框架集由Spring、MyBatis两个...
    浩云0919阅读 1,004评论 0 1
  • SSM框架整合理解 把IntelliJ IDEA+Maven+Spring + SpringMVC + MyBat...
    青年马土豆阅读 9,025评论 0 21
  • 对于java中的思考的方向,1必须要看前端的页面,对于前端的页面基本的逻辑,如果能理解最好,不理解也要知道几点。 ...
    神尤鲁道夫阅读 738评论 0 0
  • 1. 简介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的...
    笨鸟慢飞阅读 5,266评论 0 4
  • 晴;今挑战200字以上 生活把我们磨圆,磨没脾气,磨呆木...... 每天起来都不想来店里 没客人;如今开个张都是...
    维摩行止阅读 74评论 0 1