【Java报错】多数据源mapper异常more than one `primary` bean found among candidates: [sqlSessionFactory] 问题分析解决

简介: 【Java报错】多数据源mapper异常more than one `primary` bean found among candidates: [sqlSessionFactory] 问题分析解决

1. 报错分析

项目使用了多个数据源,但是没有使用持久层框架,后期加入了 mybatis-plus 插件,启动项目时报错,信息如下:

2021-08-19 09:16:20 ERROR [,,,] [main] o.s.boot.SpringApplication - Application run failed
org.springframework.beans.factory.BeanCreationException: 
Error creating bean with name 'xxxComponent': Injection of resource dependencies failed; 
nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: 
Error creating bean with name 'xxxMapper' defined in file [E:\xxx\BaseMapper.class]: 
Unsatisfied dependency expressed through bean property 'sqlSessionFactory'; 
nested exception is org.springframework.beans.factory.NoUniqueBeanDefinitionException: 
No qualifying bean of type 'org.apache.ibatis.session.SqlSessionFactory' available: 
more than one 'primary' bean found among candidates: 
[sqlSessionFactory_greenplum, sqlSessionFactory_oracle]

重要信息是 【more than one ‘primary’ bean found among candidates:
[sqlSessionFactory_greenplum, sqlSessionFactory_oracle]】
我看了一下项目的编码信息,如下【确实是2个 ✌️ 】:

@Bean(name = "sqlSessionFactory_greenplum")
@Primary
public SqlSessionFactory sqlSessionFactory(@Qualifier("ds_greenplum") DataSource dataSource) 
  throws Exception {}
@Bean(name = "sqlSessionFactory_oracle")
@Primary
public SqlSessionFactory sqlSessionFactory(@Qualifier("ds_oracle") DataSource dataSource) 
  throws Exception {}

@Primary注解可以标注出【有多个候选者有资格自动装配单值依赖项时,优先考虑的Bean对象】之前项目没有报错,说明 SqlSessionFactory 对象并不是自动装配对象,也就是说可以去掉其中一个 @Primary 就能解决问题,但是你敢随便去掉注解吗?你敢吗?🐶 反正我不敢 😅 只能寻求其他方法。

2. 问题解决

这里只贴出核心代码:

@SpringBootApplication
@MapperScan(basePackages = {"com.*.*.**.persistence"}, 
      sqlSessionFactoryRef = "sqlSessionFactory_greenplum")
@EnableScheduling
public class SpringBootApplicationStart {}

使用 basePackages 标注出你的 mapper 文件所在的文件夹,使用 sqlSessionFactoryRef 标注出你的 mapper 文件使用的 SqlSessionFactory 对象。

目录
相关文章
|
9天前
|
Java
在 Java 中捕获和处理自定义异常的代码示例
本文提供了一个 Java 代码示例,展示了如何捕获和处理自定义异常。通过创建自定义异常类并使用 try-catch 语句,可以更灵活地处理程序中的错误情况。
|
9天前
|
Java
在 Java 中,如何自定义`NumberFormatException`异常
在Java中,自定义`NumberFormatException`异常可以通过继承`IllegalArgumentException`类并重写其构造方法来实现。自定义异常类可以添加额外的错误信息或行为,以便更精确地处理特定的数字格式转换错误。
|
10天前
|
IDE 前端开发 Java
怎样避免 Java 中的 NoSuchFieldError 异常
在Java中避免NoSuchFieldError异常的关键在于确保类路径下没有不同版本的类文件冲突,避免反射时使用不存在的字段,以及确保所有依赖库版本兼容。编译和运行时使用的类版本应保持一致。
|
11天前
|
Java 编译器
如何避免在 Java 中出现 NoSuchElementException 异常
在Java中,`NoSuchElementException`通常发生在使用迭代器、枚举或流等遍历集合时,尝试访问不存在的元素。为了避免该异常,可以在访问前检查是否有下一个元素(如使用`hasNext()`方法),或者使用`Optional`类处理可能为空的情况。正确管理集合边界和条件判断是关键。
|
14天前
|
Java
Java异常捕捉处理和错误处理
Java异常捕捉处理和错误处理
14 1
|
16天前
|
Java 编译器 开发者
Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面
本文探讨了Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面,帮助开发者提高代码质量和程序的健壮性。
34 2
|
20天前
|
分布式计算 Java MaxCompute
ODPS MR节点跑graph连通分量计算代码报错java heap space如何解决
任务启动命令:jar -resources odps-graph-connect-family-2.0-SNAPSHOT.jar -classpath ./odps-graph-connect-family-2.0-SNAPSHOT.jar ConnectFamily 若是设置参数该如何设置
|
23天前
|
Java
如何在 Java 中处理“Broken Pipe”异常
在Java中处理“Broken Pipe”异常,通常发生在网络通信中,如Socket编程时。该异常表示写入操作的另一端已关闭连接。解决方法包括:检查网络连接、设置超时、使用try-catch捕获异常并进行重试或关闭资源。
|
25天前
|
存储 安全 Java
如何避免 Java 中的“ArrayStoreException”异常
在Java中,ArrayStoreException异常通常发生在尝试将不兼容的对象存储到泛型数组中时。为了避免这种异常,确保在操作数组时遵循以下几点:1. 使用泛型确保类型安全;2. 避免生类型(raw types)的使用;3. 在添加元素前进行类型检查。通过这些方法,可以有效防止 ArrayStoreException 的发生。
|
25天前
|
安全 小程序 Java
Java“AccessControlException”报错解决
Java中的“AccessControlException”通常发生在尝试访问受安全策略限制的资源时。解决方法包括:1. 检查安全策略文件(java.policy)配置;2. 确保代码具有足够的权限;3. 调整JVM启动参数以放宽安全限制。
下一篇
无影云桌面