在 Spring Boot 中以编程方式配置数据源(Configure DataSource Programmatically in Spring Boot)

Spring Boot 编程配置数据源

在 Spring Boot 中,数据源配置是基础部分,尤其是在处理数据库时。Spring Boot 提供了多种配置数据源的方法,包括使用 Spring 应用程序的 application.properties 或 application.yml 文件。在某些情况下,您可能需要以编程方式配置数据源,例如当数据库连接详细信息是动态的或需要在运行时确定时。

关键术语

  • DataSource:它是 JDBC(Java 数据库连接)API 提供的用于与数据库建立连接的接口。它提供了获取和释放数据库连接的方法。
  • DataSourceBuilder:它是 Spring Boot 提供的一个实用程序类,可以帮助以编程方式构建 DataSource 对象。它可以设置驱动程序类名称、URL、用户名和密码等属性。
  • DriverClassName:此属性用于指定 DataSource 的 JDBC 驱动类名。需要根据所使用的数据库加载相应的 JDBC 驱动类。
  • URL:它可以定义为统一资源定位符。它是一个可以指定资源位置的字符串。在配置数据源的上下文中,URL 通常表示 JDBC 连接 URL,其中包含数据库服务器地址、端口和数据库名称等详细信息。
  • 用户名和密码:这些是身份验证所需的凭据,可以与数据库服务器建立连接。用户名和密码用于访问连接 URL 中指定的数据库。

在 Spring Boot 中以编程方式理解数据源的配置

以编程方式配置数据源涉及在 Spring Boot 应用程序上下文中手动创建和配置数据源 bean,而不是依赖于外部配置文件。它可以提供更大的灵活性,并更好地控制数据源的配置。

例子

public DataSource getDataSource() {
        DataSourceBuilder dataSourceBuilder = DataSourceBuilder.create();
        dataSourceBuilder.driverClassName("org.postgresql.Driver");
        dataSourceBuilder.url("jdbc:postgresql://localhost:5432/mydatabase");
        dataSourceBuilder.username("username");
        dataSourceBuilder.password("password");
        return dataSourceBuilder.build();
    }

在这个例子中,

  • 我们创建可以用@Configuration注释的DataSourceConfig类。
  • 在类内部,我们可以定义用@Bean注释的方法,该方法可以返回应用程序的DataSource对象。
  • 我们可以使用DataSourceBuilder来创建DataSource对象并设置其属性,例如驱动程序类名称、用户名和密码。

在 Spring Boot 应用程序中手动实现 DataSource Bean 的项目

我们可以演示如何在 Spring 应用程序中以编程方式配置 DataSource。

步骤 1:使用 Spring STS IDE 创建 Spring 项目,并将下面提到的依赖项包含到项目中。

依赖项:

  • Spring Web
  • Lombok
  • Spring Data JPA
  • MySQL Driver

项目创建成功完成后,它将如下图所示:

步骤 2:创建名为 dataConfig 的新包,在同一个包中,创建名为 DataSourceConfig 的 java 类。

转到src > org.example.springdatasourceconfig > dataConfig > DataSourceConfig并输入以下代码。

DataSourceConfig.java

package org.example.springdatasourceconfig.dataConfig;


import org.springframework.boot.jdbc.DataSourceBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import javax.sql.DataSource;

@Configuration
public class DataSourceConfig {

    @Bean
    public DataSource getDataSource() {
        DataSourceBuilder dataSourceBuilder = DataSourceBuilder.create();
        dataSourceBuilder.driverClassName("com.mysql.cj.jdbc.Driver");
        dataSourceBuilder.url("jdbc:mysql://localhost:3306/example?useSSL=false&serverTimezone=UTC");
        dataSourceBuilder.username("root");
        dataSourceBuilder.password("");
        return dataSourceBuilder.build();
    }
}

步骤 3:创建名为控制器的新包,在同一个包中,创建名为HomeController的 Java 类。

转到src > org.example.springdatasourceconfig > controller > HomeController并输入以下代码:

HomeController.java

package org.example.springdatasourceconfig.controller;


import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.sql.DataSource;

@RestController
public class HomeController {

    private final DataSource dataSource;

    @Autowired
    public HomeController(DataSource dataSource) {
        this.dataSource = dataSource;
    }

    @GetMapping("/")
    public String home() {
        return "Hello from Spring Boot! DataSource: " + dataSource.toString();
    }
}

步骤4:打开主类并编写以下代码:

package org.example.springdatasourceconfig;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class SpringDatasourceConfigApplication {

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

pom.xml:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>3.2.4</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>org.example</groupId>
    <artifactId>spring-datasource-config</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>spring-datasource-config</name>
    <description>spring-datasource-config</description>
    <properties>
        <java.version>17</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.28</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <excludes>
                        <exclude>
                            <groupId>org.projectlombok</groupId>
                            <artifactId>lombok</artifactId>
                        </exclude>
                    </excludes>
                </configuration>
            </plugin>
        </plugins>
    </build>

</project>

步骤5:项目成功完成后,将应用程序作为Spring项目运行。参考下面的输出图像以便更好地理解。

端点:

获取http://localhost:8080/

输出:

如果我们按照上述步骤,我们可以在 Spring Boot 应用程序中以编程方式演示 DataSource 的配置。

如果您喜欢此文章,请收藏、点赞、评论,谢谢,祝您快乐每一天。 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hefeng_aspnet

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值