千家信息网

SpringBoot2中如何引入JdbcTemplate和多数据源配置

发表于:2024-11-20 作者:千家信息网编辑
千家信息网最后更新 2024年11月20日,这篇文章将为大家详细讲解有关SpringBoot2中如何引入JdbcTemplate和多数据源配置,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、JdbcTemp
千家信息网最后更新 2024年11月20日SpringBoot2中如何引入JdbcTemplate和多数据源配置

这篇文章将为大家详细讲解有关SpringBoot2中如何引入JdbcTemplate和多数据源配置,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

一、JdbcTemplate对象

1、JdbcTemplate简介

在Spring Boot2.0框架下配置数据源和通过JdbcTemplate访问数据库的案例。
SpringBoot对数据库的操作在jdbc上面做了深层次的封装,使用spring的注入功能,可以把DataSource注册到JdbcTemplate之中。

2、JdbcTemplate核心方法

1)execute方法:可以用于执行任何SQL语句;2)update方法batchUpdate方法:update方法用于执行新增、修改、删除等语句;batchUpdate方法用于执行批处理相关语句;3)query方法及queryFor方法:用于执行查询相关语句;4)call方法:用于执行存储过程、函数相关语句。

二、SpringBoot2中用法

1、导入Jar包

    mysql    mysql-connector-java    5.1.21    org.springframework.boot    spring-boot-starter-jdbc

2、配置数据源信息

spring:  application:    # 应用名称    name: node06-boot-jdbc  datasource:    # 数据源一:data_one 库    primary:      # 2.0开始的版本必须这样配置      jdbc-url: jdbc:mysql://localhost:3306/data_one      #url: jdbc:mysql://localhost:3306/data_one      username: root      password: 123      driver-class-name: com.mysql.jdbc.Driver    # 数据源二:data_two 库    secondary:      # 2.0开始的版本必须这样配置      jdbc-url: jdbc:mysql://localhost:3306/data_two      #url: jdbc:mysql://localhost:3306/data_two      username: root      password: 123      driver-class-name: com.mysql.jdbc.Driver

3、数据源代码配置

1)数据源一的配置
@Primary 注解表示该数据源作为默认的主数据库。

/** * 数据源一配置 */@Configurationpublic class DataOneConfig {    @Primary    // 主数据库    @Bean(name = "primaryDataSource")    @Qualifier("primaryDataSource")    @ConfigurationProperties(prefix = "spring.datasource.primary")    public DataSource primaryDataSource (){        return DataSourceBuilder.create().build() ;    }    @Bean(name = "primaryJdbcTemplate")    public JdbcTemplate primaryJdbcTemplate (            @Qualifier("primaryDataSource") DataSource dataSource){        return new JdbcTemplate(dataSource);    }}

2)数据源二配置

/** * 数据源二配置 */@Configurationpublic class DataTwoConfig {    @Bean(name = "secondaryDataSource")    @Qualifier("secondaryDataSource")    @ConfigurationProperties(prefix="spring.datasource.secondary")    public DataSource secondaryDataSource() {        return DataSourceBuilder.create().build();    }    @Bean(name = "secondaryJdbcTemplate")    public JdbcTemplate secondaryJdbcTemplate(            @Qualifier("secondaryDataSource") DataSource dataSource) {        return new JdbcTemplate(dataSource);    }}

4、编写一个简单的测试类

@RestControllerpublic class JdbcController {    private static final Logger LOG = LoggerFactory.getLogger(JdbcController.class);    // 数据源一    @Autowired    @Qualifier("primaryJdbcTemplate")    private JdbcTemplate primaryJdbcTemplate ;    // 数据源二    @Autowired    @Qualifier("secondaryJdbcTemplate")    private JdbcTemplate secondaryJdbcTemplate ;    /**     * 多数据源查询     */    @RequestMapping("/queryData")    public String queryData (){        String sql = "SELECT COUNT(1) FROM d_phone" ;        Integer countOne = primaryJdbcTemplate.queryForObject(sql,Integer.class) ;        Integer countTwo = secondaryJdbcTemplate.queryForObject(sql,Integer.class) ;        LOG.info("countOne=="+countOne+";;countTwo=="+countTwo);        return "SUCCESS" ;    }}

关于"SpringBoot2中如何引入JdbcTemplate和多数据源配置"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

0