使用SpringBoot对JDBC连接类型的数据库进行操作

1. 基本介绍

SpringBoot帮我们简化了对JDBC连接类型的数据库的操作,只需要配置spring-boot-starter-data-jdbc这个starter,然后在application.properties配置jdbc的相关配置和连接池的相关配置等,就可以对数据库进行操作了

2 自动配置分析

自动配置的类

  • DataSourceAutoConfiguration : 数据源的自动配置
    1. 修改数据源相关的配置:spring.datasource开头的配置参数

查看spring-boot-autoconfigure-2.7.5.jar,可以看到绑定了DataSourceProperties配置类

package org.springframework.boot.autoconfigure.jdbc;
......省略部分......
@EnableConfigurationProperties({DataSourceProperties.class})
@Import({DataSourcePoolMetadataProvidersConfiguration.class})
public class DataSourceAutoConfiguration {
......省略部分......
}

查看DataSourceProperties类,是由spring.datasource开头的配置参数进行配置的

......省略部分......
@ConfigurationProperties(
    prefix = "spring.datasource"
)
public class DataSourceProperties implements BeanClassLoaderAware, InitializingBean {
......省略部分......
}
  1. 数据库连接池的配置,是我们自己容器中没有DataSource才自动配置的
  2. 底层配置好的连接池是:HikariDataSource。如下所示:
package org.springframework.boot.autoconfigure.jdbc;
......省略部分......
@Configuration(
        proxyBeanMethods = false
    )
    @Conditional({PooledDataSourceCondition.class})
    @ConditionalOnMissingBean({DataSource.class, XADataSource.class})
    @Import({DataSourceConfiguration.Hikari.class, DataSourceConfiguration.Tomcat.class, DataSourceConfiguration.Dbcp2.class, DataSourceConfiguration.OracleUcp.class, DataSourceConfiguration.Generic.class, DataSourceJmxConfiguration.class})
    protected static class PooledDataSourceConfiguration {
        protected PooledDataSourceConfiguration() {
        }
    }
......省略部分......
  • DataSourceTransactionManagerAutoConfiguration: 事务管理器的自动配置
  • JdbcTemplateAutoConfiguration: JdbcTemplate的自动配置,可以来对数据库进行crud
    1. 可以修改spring.jdbc开头的参数,来修改JdbcTemplate
    2. IOC容器中,添加了JDBCTemplate模板

可以看到绑定了JdbcProperties配置类

package org.springframework.boot.autoconfigure.jdbc;
......省略部分......
@AutoConfiguration(
    after = {DataSourceAutoConfiguration.class}
)
@ConditionalOnClass({DataSource.class, JdbcTemplate.class})
@ConditionalOnSingleCandidate(DataSource.class)
@EnableConfigurationProperties({JdbcProperties.class})
@Import({DatabaseInitializationDependencyConfigurer.class, JdbcTemplateConfiguration.class, NamedParameterJdbcTemplateConfiguration.class})
public class JdbcTemplateAutoConfiguration {
    public JdbcTemplateAutoConfiguration() {
    }
}

查看JdbcProperties类,是由spring.jdbc开头的配置参数进行配置的

......省略部分......
@ConfigurationProperties(
    prefix = "spring.jdbc"
)
public class JdbcProperties {
......省略部分......
}

而且IOC容器中,也添加了JDBCTemplate组件,如下所示:

package org.springframework.boot.autoconfigure.jdbc;
......省略部分......
@Configuration(
    proxyBeanMethods = false
)
@ConditionalOnMissingBean({JdbcOperations.class})
class JdbcTemplateConfiguration {
    JdbcTemplateConfiguration() {
    }

    @Bean
    @Primary
    JdbcTemplate jdbcTemplate(DataSource dataSource, JdbcProperties properties) {
......省略部分......
    }
......省略部分......
}
  • JndiDataSourceAutoConfiguration: jndi的自动配置(tomcat会用到)
  • XADataSourceAutoConfiguration: 基于XA二阶段提交协议的分布式事务相关的自动配置

3. 实战操作

3.1 pom.xml添加依赖

添加spring-boot-starter-data-jdbc依赖。会自动导入Spring JDBC连接的依赖、HikariCP连接池依赖、Spring的transacation事务依赖

但是并没有导入具体的JDBC驱动依赖,需要我们自己手动添加。默认使用当前最新的版本号,可以通过properties方式或dependency方式指定版本号

    <properties>
        <mysql.version>8.0.31</mysql.version>
    </properties>
    
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jdbc</artifactId>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
    </dependencies>

3.2 application.properties配置

配置datasource和jdbc template的参数

# 配置datasource
spring.datasource.url=jdbc:mysql://192.168.28.12:3306/mysql
spring.datasource.username=root
spring.datasource.password=Root_123
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.type=com.zaxxer.hikari.HikariDataSource

# 配置jdbc template
spring.jdbc.template.query-timeout=3

3.3 读取数据测试

新建测试类,如下所示:

package com.hh.springboottest;

import lombok.extern.slf4j.Slf4j;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.jdbc.core.JdbcTemplate;

@Slf4j
@SpringBootTest
public class MyApplicationTest {

    @Autowired
    JdbcTemplate jdbcTemplate;

    @Test
    public void queryDataTest() {
        Long userCount = jdbcTemplate.queryForObject("select count(*) from user", Long.class);
        log.info("用户数量为{}", userCount);
    }
}

运行程序,结果如下:

......省略部分......
2022-11-18 22:02:46.151  INFO 11216 --- [           main] com.hh.springboottest.MyApplicationTest  : 用户数量为4
2022-11-18 22:02:46.172  INFO 11216 --- [ionShutdownHook] com.zaxxer.hikari.HikariDataSource       : HikariPool-1 - Shutdown initiated...
2022-11-18 22:02:46.183  INFO 11216 --- [ionShutdownHook] com.zaxxer.hikari.HikariDataSource       : HikariPool-1 - Shutdown completed.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值