Spring Boot使用JDBC连接,注入jdbc属性

这篇文章来说一下,如果使用jdbc,如何注入jdbc连接的一些属性呢?

1. 是配置文件中定义jdbc连接的属性

dataSource.driverClassName=com.mysql.cj.jdbc.Driver
dataSource.jdbcUrl=jdbc:mysql://localhost:3306/mysql?characterEncoding=utf-8&serverTimezone=GMT%2B8
dataSource.username=root
dataSource.password=root

2. 属性注入,是通过@Value("#{}"),

注意:

这种注入方式,并不是spring boot 才有的。应该是spring 的时候就已经有这个注解。

“url”这种命名一直报错,改成了"jdbcUrl"

一定是${}去取,不知道为啥刚开始写成了#{},找了半天异常。

@Component(value = "dataSourceValueConfig")
public class DataSourceValueConfig {

    @Value("${dataSource.driverClassName}")
    private String driverClassName;
    @Value("${dataSource.jdbcUrl}")
    private String jdbcUrl;
    @Value("${dataSource.username}")
    private String username;
    @Value("${dataSource.password}")
    private String password;

    public String getDriverClassName() {
        return driverClassName;
    }

    public String getJdbcUrl() {
        return jdbcUrl;
    }

    public String getUsername() {
        return username;
    }

    public String getPassword() {
        return password;
    }
}

4. 使用的时候,就正常的注入,

    @Resource
    private DataSourceValueConfig dataSourceValueConfig;

    @Resource
    private DataSourceClassConfig dataSourceClassConfig;

    private String driverClassName;
    private String jdbcUrl;
    private String userName;
    private String password;

    @PostConstruct
    public void init(){
        //dataSourceConfig = ApplicationContextBeanUtils.getBean("dataSourceConfig", DataSourceConfig.class);

        driverClassName = dataSourceValueConfig.getDriverClassName();
        jdbcUrl = dataSourceValueConfig.getJdbcUrl();
        userName = dataSourceValueConfig.getUsername();
        password = dataSourceValueConfig.getPassword();

        System.out.println("init.dataSourceConfig.driverClassName--------" + driverClassName);
        System.out.println("init.dataSourceConfig.url--------" + jdbcUrl);
        System.out.println("init.dataSourceConfig.username--------" + userName);
        System.out.println("init.dataSourceConfig.password--------" + password);


        driverClassName = dataSourceClassConfig.getDriverClassName();
        jdbcUrl = dataSourceClassConfig.getJdbcUrl();
        userName = dataSourceClassConfig.getUsername();
        password = dataSourceClassConfig.getPassword();

        System.out.println("init.dataSourceClassConfig.driverClassName--------" + driverClassName);
        System.out.println("init.dataSourceClassConfig.url--------" + jdbcUrl);
        System.out.println("init.dataSourceClassConfig.username--------" + userName);
        System.out.println("init.dataSourceClassConfig.password--------" + password);

    }

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值