【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 对象。

目录
相关文章
|
2月前
|
Java
在 Java 中捕获和处理自定义异常的代码示例
本文提供了一个 Java 代码示例,展示了如何捕获和处理自定义异常。通过创建自定义异常类并使用 try-catch 语句,可以更灵活地处理程序中的错误情况。
80 1
|
2月前
|
Java API 调度
如何避免 Java 中的 TimeoutException 异常
在Java中,`TimeoutException`通常发生在执行操作超过预设时间时。要避免此异常,可以优化代码逻辑,减少不必要的等待;合理设置超时时间,确保其足够完成正常操作;使用异步处理或线程池管理任务,提高程序响应性。
99 12
|
2月前
|
Java
在 Java 中,如何自定义`NumberFormatException`异常
在Java中,自定义`NumberFormatException`异常可以通过继承`IllegalArgumentException`类并重写其构造方法来实现。自定义异常类可以添加额外的错误信息或行为,以便更精确地处理特定的数字格式转换错误。
46 1
|
3月前
|
存储 Java
【编程基础知识】 分析学生成绩:用Java二维数组存储与输出
本文介绍如何使用Java二维数组存储和处理多个学生的各科成绩,包括成绩的输入、存储及格式化输出,适合初学者实践Java基础知识。
99 1
|
15天前
|
缓存 算法 搜索推荐
Java中的算法优化与复杂度分析
在Java开发中,理解和优化算法的时间复杂度和空间复杂度是提升程序性能的关键。通过合理选择数据结构、避免重复计算、应用分治法等策略,可以显著提高算法效率。在实际开发中,应该根据具体需求和场景,选择合适的优化方法,从而编写出高效、可靠的代码。
26 6
|
2月前
|
监控 算法 Java
jvm-48-java 变更导致压测应用性能下降,如何分析定位原因?
【11月更文挑战第17天】当JVM相关变更导致压测应用性能下降时,可通过检查变更内容(如JVM参数、Java版本、代码变更)、收集性能监控数据(使用JVM监控工具、应用性能监控工具、系统资源监控)、分析垃圾回收情况(GC日志分析、内存泄漏检查)、分析线程和锁(线程状态分析、锁竞争分析)及分析代码执行路径(使用代码性能分析工具、代码审查)等步骤来定位和解决问题。
|
2月前
|
IDE 前端开发 Java
怎样避免 Java 中的 NoSuchFieldError 异常
在Java中避免NoSuchFieldError异常的关键在于确保类路径下没有不同版本的类文件冲突,避免反射时使用不存在的字段,以及确保所有依赖库版本兼容。编译和运行时使用的类版本应保持一致。
87 7
|
2月前
|
Java 编译器
如何避免在 Java 中出现 NoSuchElementException 异常
在Java中,`NoSuchElementException`通常发生在使用迭代器、枚举或流等遍历集合时,尝试访问不存在的元素。为了避免该异常,可以在访问前检查是否有下一个元素(如使用`hasNext()`方法),或者使用`Optional`类处理可能为空的情况。正确管理集合边界和条件判断是关键。
103 6
|
2月前
|
Java
Java异常捕捉处理和错误处理
Java异常捕捉处理和错误处理
70 1
|
2月前
|
Java 编译器 开发者
Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面
本文探讨了Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面,帮助开发者提高代码质量和程序的健壮性。
88 2