栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

[springboot一本通]-4.12.2.mybatisplus+atomikos实现分布式事务

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

[springboot一本通]-4.12.2.mybatisplus+atomikos实现分布式事务

遗留问题:

前面章节介绍的多数据源的实现方式不适用于Mybatis plus Mapper。我们该如何实现Mybatis plus Mapper的多数据源以及分布式事务?

方案一:采用Mybatis Plus官网上实现的基于AOP以及注解的动态数据源切换方案。基于AOP以及注解的动态数据源切换方案。这个方案的优点是:数据源灵活切换。但缺点也同样明显:

需要为每一个类或者持久层方法指定数据源,如果编码人员素质一般,很容易错误的使用数据源。 动态切换数据源,也就意味着“从使用的角度”出错的概率变大,包括在多线程环境下可能引发的问题。从而导致错误的配置使用分布式事务。版本兼容问题有可能此起彼伏。

方案二:我们仍然采用最简的实现方式。就是将不同的数据库操作Mapper分包存放,分包注入使用不同的数据源。这种方式实现逻辑简单,万变不离其宗,是“约定大于配置”思想的体现,约定好了该放哪就放哪。虽然不灵活,但是使用方便,也不容易出错。即使出错,也容易发现(在package层面发现问题,比到代码里面去找Bug要容易的多)。

如上图:把操作testdb数据库的mapper,放在testdb目录下。把操作testdb2数据库的mapper,放在testdb2目录下。实体类其实放在哪里,并不重要。为了看上去整洁&#

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/750495.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号