1、如果同时在 @SpringBootApplication 注解中使用 exclude = DataSourceAutoConfiguration.class 参数来排除自动配置的数据源,可能会导致 @MapperScan 失效和启动报错。这是因为在排除数据源的情况下,Spring Boot 不会对 MyBatis 进行自动配置,从而无法扫描和注册 Mapper 接口。

@MapperScan("com.example.mapper")
@SpringBootApplication(exclude = DataSourceAutoConfiguration.class)
public class DbxqzfjxzApplication {

    public static void main(String[] args) {
        SpringApplication.run(DbxqzfjxzApplication.class, args);
    }

}

2、解决方法:

(1)、将 exclude = DataSourceAutoConfiguration.class 参数从 @SpringBootApplication 注解中移除,允许自动配置数据源。这样 MyBatis 的 Mapper 接口扫描将会生效。

@SpringBootApplication
@MapperScan("com.example.mapper")
public class YourApplication {
    public static void main(String[] args) {
        SpringApplication.run(YourApplication.class, args);
    }
}

(2)、在需要排除数据源的情况下,手动配置数据源并将 @MapperScan 注解放在一个独立的配置类上。在这个配置类中,使用 @Import 注解将数据源配置类引入,以确保 MyBatis 的 Mapper 接口能够被正确扫描和注册。

@Configuration
@Import(DataSourceAutoConfiguration.class)
@MapperScan("com.example.mapper")
public class MyBatisConfig {
    // 自定义数据源配置等...
}

@SpringBootApplication(exclude = DataSourceAutoConfiguration.class)
public class YourApplication {
    public static void main(String[] args) {
        SpringApplication.run(YourApplication.class, args);
    }
}
Logo

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

更多推荐