Sprngboot注解bean注入数据源报错

本文介绍了在Spring Boot中遇到的初始化Bean失败问题,具体表现为BeanCreationException,原因是数据源DataSource的初始化方法名不正确。解决方案包括修改方法名为dataSource()或者在@Bean注解中指定name属性为'dataSource'。测试类中的@Autowired注入也需对应调整。

Initialization of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.boot.autoconfigure.jdbc.DataSourceInitializerInvoker': Invocation of init method failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'dataSource': Invocation of init method failed; nested exception is java.lang.NullPointerException

代码如下:

@Configuration
@PropertySource("classpath:jdbc.properties")
public class JdbcConfiguration {

    @Value("${jdbc.driverClassName}")
    private String driverClassName;

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

    @Value("${jdbc.username}")
    private String username;

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

    @Bean
    public DataSource getDataSource(){
        DruidDataSource druidDataSource = new DruidDataSource();
        druidDataSource.setDriverClassName(driverClassName);
        druidDataSource.setUrl(url);
        druidDataSource.setUsername(username);
        druidDataSource.setPassword(password);
        return druidDataSource;
    }
}

这里有个坑,就是获取DataSource数据源不能乱写方法,比如我上面的代码写的就是getDataSource(),这样就测试类就是报错

测试类代码如下:

    @Autowired
    private JdbcConfiguration jdbcConfiguration;

    @Autowired
    private DataSource dataSource;


    @Test
    public void test(){
        System.out.println(jdbcConfiguration);
        System.out.println(dataSource);

    }

解决办法有两种方式:

1.,将上面获取数据源的方法getDataSource()改成dataSource()方法,代码如下

    @Bean
    public DataSource dataSource(){
        DruidDataSource druidDataSource = new DruidDataSource();
        druidDataSource.setDriverClassName(driverClassName);
        druidDataSource.setUrl(url);
        druidDataSource.setUsername(username);
        druidDataSource.setPassword(password);
        return druidDataSource;
    }

2.可以不局限于方法的名称,需要在bean注解后面指name属性为dataSource,代码如下:

    @Bean(name = "dataSource")
    public DataSource getDataSource(){
        DruidDataSource druidDataSource = new DruidDataSource();
        druidDataSource.setDriverClassName(driverClassName);
        druidDataSource.setUrl(url);
        druidDataSource.setUsername(username);
        druidDataSource.setPassword(password);
        return druidDataSource;
    }

在Spring Boot中使用JdbcTemplate指定数据源,可通过手动配置多个DataSource和相应的JdbcTemplate实例来实现。由于一个JdbcTemplate实例对应一个DataSource,所以只需操作对应数据源时使用相应的JdbcTemplate实例即可[^2]。 具体步骤如下: 1. **配置application.properties文件**:在单数据源时,Spring Boot只需在该文件中配置连接参数;但业务发展需配置多数据源时,要配置多个数据源的连接信息[^3]。 2. **手动提供多个DataSource**:创建多个DataSource实例,代表不同的数据源。 3. **手动配置相应的JdbcTemplate实例**:每个JdbcTemplate创建时注入对应的DataSource。因为Spring容器存在多个DataSource,默认按类型查找会报错,所以要加上`@Qualifier`注解按名称查找。例如创建两个JdbcTemplate实例,分别对应两个DataSource,创建时分别注入primaryDataSource数据源和secondaryDataSource数据源 [^4][^5]。 以下是示例代码: ```java import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.boot.jdbc.DataSourceBuilder; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.jdbc.core.JdbcTemplate; import javax.sql.DataSource; @Configuration public class DataSourceConfig { @Bean(name = "primaryDataSource") @ConfigurationProperties(prefix = "spring.datasource.primary") public DataSource primaryDataSource() { return DataSourceBuilder.create().build(); } @Bean(name = "secondaryDataSource") @ConfigurationProperties(prefix = "spring.datasource.secondary") public DataSource secondaryDataSource() { return DataSourceBuilder.create().build(); } @Bean(name = "primaryJdbcTemplate") public JdbcTemplate primaryJdbcTemplate(@Qualifier("primaryDataSource") DataSource dataSource) { return new JdbcTemplate(dataSource); } @Bean(name = "secondaryJdbcTemplate") public JdbcTemplate secondaryJdbcTemplate(@Qualifier("secondaryDataSource") DataSource dataSource) { return new JdbcTemplate(dataSource); } } ``` 在使用时,通过注入对应的JdbcTemplate实例来操作指定的数据源: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.stereotype.Service; @Service public class MyService { private final JdbcTemplate primaryJdbcTemplate; private final JdbcTemplate secondaryJdbcTemplate; @Autowired public MyService(@Qualifier("primaryJdbcTemplate") JdbcTemplate primaryJdbcTemplate, @Qualifier("secondaryJdbcTemplate") JdbcTemplate secondaryJdbcTemplate) { this.primaryJdbcTemplate = primaryJdbcTemplate; this.secondaryJdbcTemplate = secondaryJdbcTemplate; } public void doSomethingWithPrimary() { // 使用 primaryJdbcTemplate 操作主数据源 primaryJdbcTemplate.execute("SELECT * FROM table1"); } public void doSomethingWithSecondary() { // 使用 secondaryJdbcTemplate 操作从数据源 secondaryJdbcTemplate.execute("SELECT * FROM table2"); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值