多数据源事务遇到的坑:注解失效问题

问题描述:

  由于工作需要,需要在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排除在外

第二种

使用的mysql数据库,数据库引擎使用的不是InnoDB,只要切换成InnoDB就可以了

1 alter table tablename type=InnoDb

第三种

注解加的方法权限修饰符不是public,@Transational失效,修改修饰符为public

结果是,我的注解扫描范围只有controller层,所以第一种方案失败,数据库是Oracle数据库,第二种解决方案失败,方法权限修饰符就是public,第三种方案失败......

接下来,继续查找原因,然后了解到原来事务是和数据源绑定的,如果不给事务管理器qualifer属性,@Transactional默认会与第一个事务管理器绑定,结果我用的是第二个数据源,导致Transactional失效

解决方案:

配置事务管理器时添加value区分字段

java代码中添加value

1 @Transactional(value = "ynw")
2 public HashMap<String, Object> addAppointMent(Map map) {}

这样事务就可以使用了

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 47,088评论 6 342
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,650评论 19 139
  • objective-c unit test - OCMockライブラリ 最近一つiOSの単体テストライブラリを勉強...
    Chinajmz阅读 2,849评论 0 3
  • 在优酷上看到一段在2016年4月23号“世界读书日”,罗辑思维创始人罗振宇、锤子科技CEO罗永浩、大象公会创始人黄...
    驴背上的精进阅读 8,260评论 0 3
  • 黑帮片里总有这样的桥段——黑道大哥一生打打杀杀,厌倦了江湖生活,想金盆洗手从此不问江湖事。手下们纷纷劝留,撕心裂肺...
    威廉汪阅读 1,521评论 0 0