1. 首先切记!!:

mybatis多数据源的原理是根据不同包,调用不同的数据源,只需要把mapper.java和mapper.xml写在某个package中,springboot自动帮你实现数据源切换,这个不要弄错

2 配置双数据源报错

2.1.1 问题描述

org.springframework.beans.factory.BeanDefinitionStoreException: 
Failed to process import candidates for configuration class [com.telecom.SpBookActApplication]; 
nested exception is java.io.FileNotFoundException: class path resource [org/springframework/security/config/annotation/authentication/configurers/GlobalAuthenticationConfigurerAdapter.class] cannot be opened because it does not exist

2.1.2 解决方法

启动类中添加:

@SpringBootApplication(exclude = {
		org.activiti.spring.boot.SecurityAutoConfiguration.class,
	org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration.class})

2.2.1 问题描述

Failed to instantiate [org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean]:Factory method 'entityManagerFactory' threw exception;
nested exception is java.lang.IllegalArgumentException: jdbcUrl is required with driverClassName.

2.2.2 解决方法

将配置文件Application.yml中的 url:jdbc:mysql… 改为:jdbc-url: jdbc:mysql…

2.3.1 问题描述

Error creating bean with name 'bookInfoController': Unsatisfied dependency expressed through field 'iBookInfoService'; 
nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: 
Error creating bean with name 'bookInfoServiceImpl': Unsatisfied dependency expressed through field 'baseMapper'; 

2.3.2 解决方法

可能性1:实现类(XxxServiceImpl)没有加@Service注解,没有的话把这个注解加上。
可能性2:mapper类没有注入进去,可以在项目启动类上面加个全盘扫描或者指定扫描其下的任何包,注解使用它即可@MapperScan(“path”),其中path为扫描路径。

2.4.1 问题描述

NoSuchBeanDefinitionException:
No qualifying bean of type ‘com.telecom.dao.BookDao’ available: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)}

2.4.2 解决方法

在写了mapper层的情况下还忘记删掉之前写的的dao层,导致重复了

2.5.1 问题描述

***************************
APPLICATION FAILED TO START
***************************

Description:

An attempt was made to call a method that does not exist. The attempt was made from the following location:

   org.mybatis.spring.SqlSessionFactoryBean.buildSqlSessionFactory(SqlSessionFactoryBean.java:564)

The following method did not exist:

'void org.apache.ibatis.session.Configuration.setDefaultEnumTypeHandler(java.lang.Class)'

2.5.2 解决方法

这种一般都是由于版本依赖冲突引起的问题,用maven-helper检查一下依赖冲突,exclude一下,但是发现还是不行,但是删了本地重复的版本文件也不行。

2.6.1 问题描述

jar:file:/D:/programs/apache-maven-3.6.1/mvn_resp/org/mybatis/mybatis-spring/2.0.6/mybatis-spring-2.0.6.jar!/org/mybatis/spring/SqlSessionFactoryBean.class

The called method’s class, org.apache.ibatis.session.Configuration, is available from the following locations:

jar:file:/D:/programs/apache-maven-3.6.1/mvn_resp/org/mybatis/mybatis/3.4.2/mybatis-3.4.2.jar!/org/apache/ibatis/session/Configuration.class

The called method’s class hierarchy was loaded from the following locations:

org.apache.ibatis.session.Configuration: file:/D:/programs/apache-maven-3.6.1/mvn_resp/org/mybatis/mybatis/3.4.2/mybatis-3.4.2.jar
Action:

Correct the classpath of your application so that it contains compatible versions of the classes org.mybatis.spring.SqlSessionFactoryBean and org.apache.ibatis.session.Configuration

2.6.2 解决方法

这是因为多个版本的依赖,找到mybatis-spring这个2.0.6依赖删除即可

2.7.1 问题描述

java.lang.IllegalStateException:
Failed to introspect Class [com.telecom.config.PrimaryDataSourceConfig] from ClassLoader [jdk.internal.loader.ClassLoaders$AppClassLoader@2f0e140b]
Caused by: java.lang.NoClassDefFoundError: org/apache/ibatis/session/SqlSessionFactory
Caused by: java.lang.ClassNotFoundException: org.apache.ibatis.session.SqlSessionFactory

2.7.2 解决方法

这个报错其实就是没有找到要加载的类,一般在启动的时候报错。
加载不到的类有两种情况,一种是直接找不到要加载的依赖包,或者添加了依赖包后没有加载进入,需要看看是不是 maven 的设置问题,重新刷新加载一下 maven 的依赖,或者清一下 idea 的缓存;
另外一种是导入了依赖包,但是依赖包中又引入了其他的依赖包中的类,这个类找不到。

2.8.1 问题描述

An attempt was made to call a method that does not exist. The attempt was made from the following location:

com.baomidou.mybatisplus.core.MybatisMapperAnnotationBuilder.getLanguageDriver(MybatisMapperAnnotationBuilder.java:384)

2.8.2 解决方法

com.baomidou.mybatisplus.core.MybatisMapperAnnotationBuilder.getLanguageDriver方法不存在
原因:activiti包中的 org.mybatis 包 和 mybatisPlus中的org.mybatis 包冲突。
需要排除掉activiti包中的 org.mybatis 包。

       <dependency>
            <groupId>org.activiti</groupId>
            <artifactId>activiti-spring-boot-starter-basic</artifactId>
            <version>6.0.0</version>
            <exclusions>
                <exclusion>
                    <artifactId>mybatis</artifactId>
                    <groupId>org.mybatis</groupId>
                </exclusion>
            </exclusions>
        </dependency>

2.9.1 问题描述

org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name ‘deployApplications’ defined in class path resource [org/activiti/application/conf/ApplicationAutoConfiguration.class]:
Unsatisfied dependency expressed through method ‘deployApplications’ parameter 2;

nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name ‘processEntryDeployer’ defined in class path resource [org/activiti/application/conf/ApplicationProcessAutoConfiguration.class]: Unsatisfied dependency expressed through method ‘processEntryDeployer’ parameter 0;

nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name ‘repositoryServiceBean’ defined in class path resource [org/activiti/spring/boot/JpaProcessEngineAutoConfiguration/JpaConfiguration.class]: Unsatisfied dependency expressed through method ‘repositoryServiceBean’ parameter 0; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name ‘processEngine’ defined in class path resource [org/activiti/spring/boot/JpaProcessEngineAutoConfiguration$JpaConfiguration.class]: Unsatisfied dependency expressed through method ‘processEngine’ parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name ‘springProcessEngineConfiguration’ defined in class path resource [org/activiti/spring/boot/JpaProcessEngineAutoConfig

2.9.2 解决方法

在创建SqlSessionFactoryBean bean = new SqlSessionFactoryBean();针对mybatis;若是项目中使用了mybatis,则需要替换成:MybatisSqlSessionFactoryBean bean = new MybatisSqlSessionFactoryBean(); 否则会报错:找不到baseMapper中的方法;

3 整合Activiti工作流报错

3.1.1 问题描述

Parameter 1 of method springProcessEngineConfiguration in org.activiti.spring.boot.JpaProcessEngineAutoConfiguration$JpaConfiguration required a bean of type 'javax.persistence.EntityManagerFactory' that could not be found.

3.1.2 解决方法

// 第一种方式 指定工作流单独的数据源
@Configuration
public class ActivitiDatasourceConfig extends AbstractProcessEngineAutoConfiguration {
 
  @Bean
  @Primary
  @ConfigurationProperties(prefix = "spring.datasource.activiti")
  public DataSource activitiDataSource() {
    return DataSourceBuilder.create().build();
  }
 
  @Bean
  public SpringProcessEngineConfiguration springProcessEngineConfiguration(
      PlatformTransactionManager transactionManager,
      SpringAsyncExecutor springAsyncExecutor) throws IOException {
 
    return baseSpringProcessEngineConfiguration(activitiDataSource(), transactionManager, springAsyncExecutor);
  }
 
}
 
 
 
// 第二种方式 使用已有的数据源
@Configuration
public class ActivitiConfig extends AbstractProcessEngineAutoConfiguration {
    static final String NAME = "master";
    //注入数据源和事务管理器
    @Bean
    public SpringProcessEngineConfiguration springProcessEngineConfiguration(
            SpringAsyncExecutor springAsyncExecutor) throws IOException {
            @Qualifier(NAME + "DataSource") DataSource dataSource,
            @Qualifier(NAME + "TransactionManager") PlatformTransactionManager transactionManager,
            
        return this.baseSpringProcessEngineConfiguration(dataSource, transactionManager, springAsyncExecutor);
    }
}

此问题参考博客: https://blog.csdn.net/weixin_29300375/article/details/81181333

3.2.1 问题描述

***************************
APPLICATION FAILED TO START
***************************
Description:

Failed to configure a DataSource: 'url' attribute is not specified and no embedded datasource could be configured.

Reason: Failed to determine a suitable driver class

3.2.2 解决方法

八成是application.yml文件中配置数据源啥的有问题
我是因为改动了配置数据源的路径spring.datasource.dynamic.datasource 后,但是忘记在项目的其他地方改一下这个配置文件中的路径
也可能是其他问题引起的:https://blog.csdn.net/qq_45498460/article/details/112860809

3.3.1 问题描述

Could not update Activiti database schema: unknown version from database: '7.0.0.0'

3.3.2 解决方法

这个可能是activiti下activiti-spring-boot-starter-basic包版本异常引起的数据库错误,需要如下图检查一下ProcessEngine.java里和数据库里的act_ge_property表里版本号是否一致,不一致的话将数据库中act_ge_property表中的版本号中的的版本和和pom.xml中activiti-spring-boot-starter-basic包下db.create下sql 文件中的版本对应。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
这个问题也是苦苦寻找好久解决方法,最后参考的这个文章找到的这个解决办法https://blog.csdn.net/qq_41169544/article/details/122810066
,瞬间柳暗花明又一村了。

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐