mybatis-plus中使用的dynamic-datasource-spring-boot-starter 里的 @DS 功能.
业务需要切换数据源,后台配置双数据源用于处理kafka生产者发送过来的实时数据,kafka消费者后台配置主从库双数据源。
难受的是主从库,库名表名列个数均不同,一开始就报找不到某列,Unknown Column ‘xxx’,找了半天发现,debug进入业务发现使用的一直是主库,从主库查询到的数据实体当然封装不到从库的数据实体,所以就报某字段未定义找不到未知这样的错。
阐述下我犯的错。就是因为在业务实现类上开启了事务,我个憨憨
整理@DS的用法:@DS可以注解在方法上、类上、接口、枚举,同时存在方法注解优先于类上注解。
常见问题:涉及需要切换数据源时,
1.不能使用事务,否则数据源不会切换,使用的还是是第一次加载的数据源 。
删除 操作多数据源的方法或者类、接口 上的 注解 @Transactional() 即可。
2.第一次加载的数据源之后,第二次(第三次...)操作其它数据源,如果数据源不存在,使用的还是第一次加载的数据源 3.数据源名称最好不要包含下滑线,下滑线的数据源切换不了



