溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

SpringBoot2中如何引入JdbcTemplate和多數(shù)據(jù)源配置

發(fā)布時(shí)間:2021-11-30 16:25:38 來源:億速云 閱讀:187 作者:小新 欄目:編程語言

這篇文章將為大家詳細(xì)講解有關(guān)SpringBoot2中如何引入JdbcTemplate和多數(shù)據(jù)源配置,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

一、JdbcTemplate對(duì)象

1、JdbcTemplate簡介

在Spring Boot2.0框架下配置數(shù)據(jù)源和通過JdbcTemplate訪問數(shù)據(jù)庫的案例。
SpringBoot對(duì)數(shù)據(jù)庫的操作在jdbc上面做了深層次的封裝,使用spring的注入功能,可以把DataSource注冊(cè)到JdbcTemplate之中。

2、JdbcTemplate核心方法

1)execute方法:可以用于執(zhí)行任何SQL語句;
2)update方法batchUpdate方法:update方法用于執(zhí)行新增、修改、刪除等語句;batchUpdate方法用于執(zhí)行批處理相關(guān)語句;
3)query方法及queryFor方法:用于執(zhí)行查詢相關(guān)語句;
4)call方法:用于執(zhí)行存儲(chǔ)過程、函數(shù)相關(guān)語句。

二、SpringBoot2中用法

1、導(dǎo)入Jar包

<!-- 數(shù)據(jù)庫依賴 -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.21</version>
</dependency>
<!-- JDBC 依賴 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

2、配置數(shù)據(jù)源信息

spring:
  application:
    # 應(yīng)用名稱
    name: node06-boot-jdbc
  datasource:
    # 數(shù)據(jù)源一: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
    # 數(shù)據(jù)源二: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、數(shù)據(jù)源代碼配置

1)數(shù)據(jù)源一的配置
@Primary 注解表示該數(shù)據(jù)源作為默認(rèn)的主數(shù)據(jù)庫。

/**
 * 數(shù)據(jù)源一配置
 */
@Configuration
public class DataOneConfig {
    @Primary    // 主數(shù)據(jù)庫
    @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)數(shù)據(jù)源二配置

/**
 * 數(shù)據(jù)源二配置
 */
@Configuration
public 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、編寫一個(gè)簡單的測試類

@RestController
public class JdbcController {
    private static final Logger LOG = LoggerFactory.getLogger(JdbcController.class);
    // 數(shù)據(jù)源一
    @Autowired
    @Qualifier("primaryJdbcTemplate")
    private JdbcTemplate primaryJdbcTemplate ;
    // 數(shù)據(jù)源二
    @Autowired
    @Qualifier("secondaryJdbcTemplate")
    private JdbcTemplate secondaryJdbcTemplate ;
    /**
     * 多數(shù)據(jù)源查詢
     */
    @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" ;
    }
}

關(guān)于“SpringBoot2中如何引入JdbcTemplate和多數(shù)據(jù)源配置”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI