欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用@DS輕松解決動(dòng)態(tài)數(shù)據(jù)源的問題

 更新時(shí)間:2022年05月23日 09:18:23   作者:ReCodingLife  
這篇文章主要介紹了使用@DS輕松解決動(dòng)態(tài)數(shù)據(jù)源的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

@DS解決動(dòng)態(tài)數(shù)據(jù)源問題

動(dòng)態(tài)切換數(shù)據(jù)源,無非是繼承org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource這個(gè)類,重寫determineCurrentLookupKey()這個(gè)方法,動(dòng)態(tài)變換數(shù)據(jù)源的key值,有人已經(jīng)將詳細(xì)代碼封裝到框架中,我們只需要使用它的注解@DS就好。

引入maven

<!-- https://mvnrepository.com/artifact/com.baomidou/dynamic-datasource-spring-boot-starter -->
? ? ? ? <dependency>
? ? ? ? ? ? <groupId>com.baomidou</groupId>
? ? ? ? ? ? <artifactId>dynamic-datasource-spring-boot-starter</artifactId>
? ? ? ? ? ? <version>3.2.1</version>
? ? ? ? </dependency>

修改Application.yml

參考的是官網(wǎng)的例子

spring:
? datasource:
? ? dynamic:
? ? ? primary: master #設(shè)置默認(rèn)的數(shù)據(jù)源或者數(shù)據(jù)源組,默認(rèn)值即為master
? ? ? strict: false #設(shè)置嚴(yán)格模式,默認(rèn)false不啟動(dòng). 啟動(dòng)后在未匹配到指定數(shù)據(jù)源時(shí)候會(huì)拋出異常,不啟動(dòng)則使用默認(rèn)數(shù)據(jù)源.
? ? ? datasource:
? ? ? ? master:
? ? ? ? ? url: jdbc:mysql://xx.xx.xx.xx:3306/dynamic
? ? ? ? ? username: root
? ? ? ? ? password: 123456
? ? ? ? ? driver-class-name: com.mysql.jdbc.Driver # 3.2.0開始支持SPI可省略此配置
? ? ? ? slave_1:
? ? ? ? ? url: jdbc:mysql://xx.xx.xx.xx:3307/dynamic
? ? ? ? ? username: root
? ? ? ? ? password: 123456
? ? ? ? ? driver-class-name: com.mysql.jdbc.Driver
? ? ? ? slave_2:
? ? ? ? ? url: ENC(xxxxx) # 內(nèi)置加密,使用請(qǐng)查看詳細(xì)文檔
? ? ? ? ? username: ENC(xxxxx)
? ? ? ? ? password: ENC(xxxxx)
? ? ? ? ? driver-class-name: com.mysql.jdbc.Driver
? ? ? ? ? schema: db/schema.sql # 配置則生效,自動(dòng)初始化表結(jié)構(gòu)
? ? ? ? ? data: db/data.sql # 配置則生效,自動(dòng)初始化數(shù)據(jù)
? ? ? ? ? continue-on-error: true # 默認(rèn)true,初始化失敗是否繼續(xù)
? ? ? ? ? separator: ";" # sql默認(rèn)分號(hào)分隔符
? ? ? ? ??
? ? ? ?#......省略
? ? ? ?#以上會(huì)配置一個(gè)默認(rèn)庫master,一個(gè)組slave下有兩個(gè)子庫slave_1,slave_2

這是我自己的:

spring:
? datasource:
? ? dynamic:
? ? ? primary: master #設(shè)置默認(rèn)的數(shù)據(jù)源或者數(shù)據(jù)源組,默認(rèn)值即為master #設(shè)置嚴(yán)格模式,默認(rèn)false不啟動(dòng). 啟動(dòng)后在未匹配到指定數(shù)據(jù)源時(shí)候會(huì)拋出異常,不啟動(dòng)則使用默認(rèn)數(shù)據(jù)源.
? ? ? datasource:
? ? ? ? master:
? ? ? ? ? url: jdbc:sqlserver://127.0.0.1:1433;DatabaseName=balabala
? ? ? ? ? username: sa
? ? ? ? ? password: 123456Sa
? ? ? ? ? driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver
? ? ? ? sub:
? ? ? ? ? url: jdbc:mysql://127.0.0.1:3307/balabala?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
? ? ? ? ? username: sa
? ? ? ? ? password: 123456Sa
? ? ? ? ? driver-class-name: com.mysql.cj.jdbc.Driver

在需要使用非默認(rèn)數(shù)據(jù)庫的dao層的方法上加上注解@DS(“數(shù)據(jù)庫名”)即可

@DS("sub")
int selectBusiness(@Param("startTime") String startTime,
? ? ? ? ? ? ? ? ? ?@Param("endTime") String endTime,
? ? ? ? ? ? ? ? ? ?@Param("businessType") String businessType);

@DS注解說明

寫法:

@DS(value = "數(shù)據(jù)源名稱")
datasource:?
數(shù)據(jù)源名臣

注解在類上或方法上來切換數(shù)據(jù)源

Gradle:

com.baomidou:dynamic-datasource-spring-boot-starter:2.5.3

打開一個(gè)線程得方法

new Thread(() -> {
? ? 方法內(nèi)容-------------------------------------
}).start();

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • java實(shí)現(xiàn)簡(jiǎn)單銀行家算法

    java實(shí)現(xiàn)簡(jiǎn)單銀行家算法

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)簡(jiǎn)單銀行家算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • 關(guān)于Spring MVC在Controller層中注入request的坑詳解

    關(guān)于Spring MVC在Controller層中注入request的坑詳解

    這篇文章主要給大家介紹了關(guān)于Spring MVC在Controller層中注入request的坑的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-04-04
  • Java編程一維數(shù)組轉(zhuǎn)換成二維數(shù)組實(shí)例代碼

    Java編程一維數(shù)組轉(zhuǎn)換成二維數(shù)組實(shí)例代碼

    這篇文章主要介紹了Java編程一維數(shù)組轉(zhuǎn)換成二維數(shù)組,分享了相關(guān)代碼示例,小編覺得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2018-01-01
  • maven私服的配置使用方法

    maven私服的配置使用方法

    這篇文章主要介紹了maven私服的配置使用方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • SpringBoot3中數(shù)據(jù)庫集成實(shí)踐詳解

    SpringBoot3中數(shù)據(jù)庫集成實(shí)踐詳解

    項(xiàng)目工程中,集成數(shù)據(jù)庫實(shí)現(xiàn)對(duì)數(shù)據(jù)的增曬改查管理,是最基礎(chǔ)的能力,所以下面小編就來和大家講講SpringBoot3如何實(shí)現(xiàn)數(shù)據(jù)庫集成,需要的可以參考下
    2023-08-08
  • 關(guān)于Mybatis使用collection分頁問題

    關(guān)于Mybatis使用collection分頁問題

    項(xiàng)目中mybatis分頁的場(chǎng)景是非常高頻的,當(dāng)使用ResultMap并配置collection做分頁的時(shí)候,我們可能會(huì)遇到獲取當(dāng)前頁的數(shù)據(jù)少于每頁大小的數(shù)據(jù)問題。接下來通過本文給大家介紹Mybatis使用collection分頁問題,感興趣的朋友一起看看吧
    2021-11-11
  • SpringBoot啟動(dòng)后啟動(dòng)內(nèi)嵌瀏覽器的方法

    SpringBoot啟動(dòng)后啟動(dòng)內(nèi)嵌瀏覽器的方法

    這篇文章主要介紹了SpringBoot啟動(dòng)后啟動(dòng)內(nèi)嵌瀏覽器的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • Java 判斷字符串a(chǎn)和b是否互為旋轉(zhuǎn)詞

    Java 判斷字符串a(chǎn)和b是否互為旋轉(zhuǎn)詞

    本篇文章主要介紹了判斷字符串a(chǎn)和b是否互為旋轉(zhuǎn)詞的相關(guān)知識(shí),具有很好的參考價(jià)值。下面跟著小編一起來看下吧
    2017-05-05
  • Java Eureka探究細(xì)枝末節(jié)

    Java Eureka探究細(xì)枝末節(jié)

    Eureka是Netflix開發(fā)的服務(wù)發(fā)現(xiàn)框架,本身是一個(gè)基于REST的服務(wù),主要用于定位運(yùn)行在AWS域中的中間層服務(wù),以達(dá)到負(fù)載均衡和中間層服務(wù)故障轉(zhuǎn)移的目的
    2022-09-09
  • SpringBoot Jpa分頁查詢配置方式解析

    SpringBoot Jpa分頁查詢配置方式解析

    這篇文章主要介紹了SpringBoot Jpa分頁查詢配置方式解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02

最新評(píng)論