SSM整合遇到的问题,非常干货,希望能帮助到您~

你们好,我是金金金。

无法自动装配

  • 配置类已经配置了扫描

那是什么原因导致?

解决

  • 很明显位置都不在一起,需要更改。

结果类型不匹配select id="selectEmployeeByCondition"

什么原因导致?

  • 这个是因为我建立了很多子模块 名字一样导致找到别的包下面去了

解决

  • 更改名称即可

java.sql.SQLException: url not set

什么原因导致?

  • 当你在Spring配置类中添加了sqlSessionFactoryBeanmapperScannerConfigurer配置方法时,可能会导致@Value注解读取不到值为null的问题。这是因为SqlSessionFactoryBeanMapperScannerConfigurer是基于MyBatis框架的配置,它们的初始化顺序可能会导致属性注入的问题。
    SqlSessionFactoryBeanMapperScannerConfigurer在配置类中通常是用来配置MyBatis相关的Bean,例如数据源、事务管理器、Mapper扫描等。这些配置类通常在@Configuration注解下定义,并且使用@Value注解来注入属性值。
    当配置类被加载时,Spring容器会首先处理Bean的定义和初始化,其中包括sqlSessionFactoryBeanmapperScannerConfigurer的初始化。在这个过程中,如果@Value注解所在的Bean还没有被完全初始化,可能会导致注入的属性值为null。

解决

  • 分成两个配置类独立配置,互不影响,数据库提取一个配置类,mybatis提取一个配置类即可解决!

数据库配置类(DataSourceJavaConfig.java

java 复制代码
@Configuration
@PropertySource("classpath:jdbc.properties")
public class DataSourceJavaConfig {


    @Value("${jdbc.user}")
    private String user;
    @Value("${jdbc.password}")
    private String password;
    @Value("${jdbc.url}")
    private String url;
    @Value("${jdbc.driver}")
    private String driver;


    //数据库连接池配置
    @Bean
    public DataSource dataSource(){
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setUsername(user);
        dataSource.setPassword(password);
        dataSource.setUrl(url);
        dataSource.setDriverClassName(driver);
        return dataSource;
    }

}

mybatis配置类(MapperJavaConfig.java

java 复制代码
@Configuration // 配置类
public class MapperJavaConfig {
/**
   * 配置SqlSessionFactoryBean,用于创建SqlSessionFactory。
   * 这个方法需要一个DataSource作为参数,用来设置SqlSessionFactoryBean的dataSource属性。
   * 它还从类路径下的"mybatis-config.xml"文件中加载MyBatis的配置。
   *
   * @param dataSource 数据源对象,用于数据库连接。
   * @return SqlSessionFactoryBean配置对象,可用于创建SqlSessionFactory。
   */
  @Bean
  public SqlSessionFactoryBean sqlSessionFactoryBean(DataSource dataSource) {
    SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
    sqlSessionFactoryBean.setDataSource(dataSource); // 设置数据源

    Resource resource = new ClassPathResource("mybatis-config.xml"); // 加载配置文件
    sqlSessionFactoryBean.setConfigLocation(resource);
    return sqlSessionFactoryBean;
  }
  /**
   * 配置MapperScannerConfigurer,用于扫描指定包下的Mapper接口。
   * 该方法不接受任何参数,返回一个配置好的MapperScannerConfigurer实例。
   *
   * @return MapperScannerConfigurer 配置了基础包名的MapperScannerConfigurer实例。
   */
  @Bean
  public MapperScannerConfigurer mapperScannerConfigurer() {
    MapperScannerConfigurer mapperScannerConfigurer = new MapperScannerConfigurer();
    mapperScannerConfigurer.setBasePackage("com.yjx.mapper"); // //设置mapper接口和xml文件所在的共同包
    return mapperScannerConfigurer;
  }
}

Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type 'javax.sql.DataSource' available: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {}

  • 意思是:没有类型为"javax.sql"的合格bean。数据源可用:预计至少有1个bean符合自动候选条件

什么原因导致?

  • 因为第3点我拆成了两个配置文件,导致sqlSessionFactoryBean方法里面找不到dataSource了

解决

  • 编写有误还请大佬指正,万分感谢。
相关推荐
野犬寒鸦4 小时前
从零起步学习并发编程 || 第一章:初步认识进程与线程
java·服务器·后端·学习
我爱娃哈哈4 小时前
SpringBoot + Flowable + 自定义节点:可视化工作流引擎,支持请假、报销、审批全场景
java·spring boot·后端
李梨同学丶6 小时前
0201好虫子周刊
后端
思想在飞肢体在追6 小时前
Springboot项目配置Nacos
java·spring boot·后端·nacos
Loo国昌8 小时前
【垂类模型数据工程】第四阶段:高性能 Embedding 实战:从双编码器架构到 InfoNCE 损失函数详解
人工智能·后端·深度学习·自然语言处理·架构·transformer·embedding
ONE_PUNCH_Ge9 小时前
Go 语言泛型
开发语言·后端·golang
良许Linux9 小时前
DSP的选型和应用
后端·stm32·单片机·程序员·嵌入式
不光头强9 小时前
spring boot项目欢迎页设置方式
java·spring boot·后端
怪兽毕设10 小时前
基于SpringBoot的选课调查系统
java·vue.js·spring boot·后端·node.js·选课调查系统
学IT的周星星10 小时前
Spring Boot Web 开发实战:第二天,从零搭个“会卖萌”的小项目
spring boot·后端·tomcat