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

mybatis-plus双数据源@DS踩坑

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

mybatis-plus双数据源@DS踩坑

mybatis-plus中使用的dynamic-datasource-spring-boot-starter 里的 @DS 功能.

业务需要切换数据源,后台配置双数据源用于处理kafka生产者发送过来的实时数据,kafka消费者后台配置主从库双数据源。
难受的是主从库,库名表名列个数均不同,一开始就报找不到某列,Unknown Column ‘xxx’,找了半天发现,debug进入业务发现使用的一直是主库,从主库查询到的数据实体当然封装不到从库的数据实体,所以就报某字段未定义找不到未知这样的错。
阐述下我犯的错。就是因为在业务实现类上开启了事务,我个憨憨

整理@DS的用法:@DS可以注解在方法上、类上、接口、枚举,同时存在方法注解优先于类上注解。

常见问题:涉及需要切换数据源时,

  1.不能使用事务,否则数据源不会切换,使用的还是是第一次加载的数据源 。

删除 操作多数据源的方法或者类、接口 上的 注解 @Transactional() 即可。

  2.第一次加载的数据源之后,第二次(第三次...)操作其它数据源,如果数据源不存在,使用的还是第一次加载的数据源

  3.数据源名称最好不要包含下滑线,下滑线的数据源切换不了
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/322959.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

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

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