多数据源事务注解失效问题
问题描述:
由于工作需要,需要在spring中配置两个数据源,有一天突然发现@transactional注解失效
环境框架:
springmvc+spring+spring jdbctemplate
数据库:
oracle数据库
解决方法:
百度获得三种可能原因及相应解决方案:
第一种
1 <!– 自动扫描的包名 –> 2 <context:component-scan base-package=“com.yxyj” > 3 </context:component-scan>
spring容器优先加载由servletcontextlistener(对应applicationcontext.xml)产生的父容器,而springmvc(对应mvc_dispatcher_servlet.xml)产生的是子容器。子容器controller进行扫描装配时装配的@service注解的实例是没有经过事务加强处理,即没有事务处理能力的service,而父容器进行初始化的service是保证事务的增强处理能力的。如果不在子容器中将service exclude掉,此时得到的将是原样的无事务处理能力的service。
springmvc的配置文件里包扫描范围太大,应该将service排除在外
1 <context:component-scan base-package=“com.will” > 2 <context:exclude-filter type=“annotation” expression=“org.springframework.stereotype.service” /> 3 </context:component-scan>
第二种
使用的mysql数据库,数据库引擎使用的不是innodb,只要切换成innodb就可以了
1 alter table tablename type=innodb
第三种
注解加的方法权限修饰符不是public,@transational失效,修改修饰符为public
结果是,我的注解扫描范围只有controller层,所以第一种方案失败,数据库是oracle数据库,第二种解决方案失败,方法权限修饰符就是public,第三种方案失败......
接下来,继续查找原因,然后了解到原来事务是和数据源绑定的,如果不给事务管理器qualifer属性,@transactional默认会与第一个事务管理器绑定,结果我用的是第二个数据源,导致transactional失效
解决方案:
配置事务管理器时添加value区分字段
<bean id="transactionmanager02" class="org.springframework.jdbc.datasource.datasourcetransactionmanager"> <property name="datasource" ref="datasource02" /> <qualifier value="ynw"></qualifier> </bean>
java代码中添加value
1 @transactional(value = "ynw") 2 public hashmap<string, object> addappointment(map map) {}
这样事务就可以使用了
推荐阅读
-
Spring事务失效问题分析及解决方案
-
使用@Transactional注解事务,可能出现哪些问题呢
-
Spring MVC @Transactional注解方式事务失效的解决办法
-
@DS注解在 @PostConstruct 事件中失效的问题解决 javamybatisplusspringboot
-
@DS注解在 @PostConstruct 事件中失效的问题解决 javamybatisplusspringboot
-
MyBatis注解开发中传多参问题
-
spring声明事务失效问题
-
多数据源事务注解失效问题
-
自定义事务管理器的实现 以应对同一个系统多个数据源@Transactional事务 失效问题
-
Spring 下,关于动态数据源的事务问题的探讨