Spring Boot DataSource的建立方法

摘要

看完本文你将掌握以下知识点:mysql

  1. Spring Boot项目中DataSource的建立方法

DataSource的建立方法

前面讲了不少Spring Boot数据访问方面的内容,在讲到本身扩展数据访问的时候,示例代码中给出的DataSource建立方式都是DriverManagerDataSource,好比:spring

#datasource
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/springboot1?useUnicode=true&characterEncoding=utf-8
spring.datasource.username=root
spring.datasource.password=newpwd
@Value("${spring.datasource.driver-class-name}")
    String driverClass;
    @Value("${spring.datasource.url}")
    String url;
    @Value("${spring.datasource.username}")
    String userName;
    @Value("${spring.datasource.password}")
    String passWord;

    @Bean(name = "dataSource")
    public DataSource dataSource() {

        DriverManagerDataSource dataSource = new DriverManagerDataSource();
        dataSource.setDriverClassName(driverClass);
        dataSource.setUrl(url);
        dataSource.setUsername(userName);
        dataSource.setPassword(passWord);
        return dataSource;
    }

若是有多个数据源,就再建立多个DriverManagerDataSource
通常生产项目中咱们不会这样使用,一般能够使用org.apache.commons.dbcp.BasicDataSourcesql

实际上Spring Boot为咱们提供了简便的建立DataSource的方法:apache

#datasource
#须要执行数据源的类型
spring.datasource.ds1.type=org.apache.tomcat.jdbc.pool.DataSource
spring.datasource.ds1.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.ds1.url=jdbc:mysql://localhost:3306/springboot1?useUnicode=true&characterEncoding=utf-8
spring.datasource.ds1.username=root
spring.datasource.ds1.password=newpwd

spring.datasource.ds2.type=org.apache.tomcat.jdbc.pool.DataSource
spring.datasource.ds2.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.ds2.url=jdbc:mysql://localhost:3306/springboot2?useUnicode=true&characterEncoding=utf-8
spring.datasource.ds2.username=root
spring.datasource.ds2.password=newpwd
@Bean(name = "dataSource1")
    //application.properties中属性名称的前缀
    @ConfigurationProperties(prefix = "spring.datasource.ds1")
    public DataSource dataSource1() {
        return DataSourceBuilder.create().build();
    }

    @Bean(name = "dataSource2")
    @ConfigurationProperties(prefix = "spring.datasource.ds2")
    public DataSource dataSource2() {
        return DataSourceBuilder.create().build();
    }

目前,此种方式支持以下几种数据源类型:tomcat

"org.apache.tomcat.jdbc.pool.DataSource", "com.zaxxer.hikari.HikariDataSource", "org.apache.commons.dbcp.BasicDataSource", "org.apache.commons.dbcp2.BasicDataSource"springboot

使用哪一种数据源类型,就要在项目中加入相应的jar依赖,
好比org.apache.tomcat.jdbc.pool.DataSourceapp

<dependency>
    <groupId>org.apache.tomcat</groupId>
    <artifactId>tomcat-jdbc</artifactId>
    <version>8.5.6</version>
</dependency>
相关文章
相关标签/搜索