SpringBoot集成ShardingSphere-JDBC、dynamic-datasource-spring-boot-starter,切换数据源后分库分表规则无效
问题:添加@DS
,规则失效。切换数据源是成功的,但规则没有生效
原因:因方法添加@Transactional
注解导致
数据源是否成功:
// 在添加@DS的方法内部执行如下代码
// 结果为执行本次代码时,持有的数据源名。注意这个只是表明多数据源切换是否成功,不代表拿这个数据源真正执行后续方法
String dataSourceName = DynamicDataSourceContextHolder.peek();
理解:
- 在方法1中调用方法2,且方法1被
@Transactional
修饰,如果方法2使用@DS
切换数据源将会失效。原因:@Transactional
修饰方法时,Spring会维护一个connection对象,保证在事务下整个线程后续拿到的是同一个connection对象,故执行到内部方法时,切换了数据源,Spring在做事务提交时拿到的也是维护的connection对象,并不会拿到切换数据源后的connection对象。 @Transactional
和@DS
可以连用,因为会先触发切换数据源,后开启事务。维护的connection对象也是切换数据源之后的connection对象
解决方案:
1.检查添加@DS
所在的方法 是否 为 本次测试功能的直接业务方法,即Contrller代码中直接调用 添加 @DS的所在方法
2.如果不是直接业务方法,则判断外层业务方法是否添加@Transactional
。如果添加则去除。或者在外层业务方法上添加@DS
强烈建议:不要在一个事务中切换数据源。切换数据源会导致事务失效