日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

一個注解搞定多數據源切換,你學會了嗎?

來源: 責編: 時間:2023-11-28 09:36:31 291觀看
導讀我們都知道,再開發的過程中,對于多個數據庫,就會有各種各樣的數據源,比如Oracle,比如 Mysql,并且再開發的過程中,我們很有可能會同時使用到兩個數據庫,這樣就設計到了切換不同的數據源來進行實現,就比如我們在 Oracle 的數據

我們都知道,再開發的過程中,對于多個數據庫,就會有各種各樣的數據源,比如Oracle,比如 Mysql,并且再開發的過程中,我們很有可能會同時使用到兩個數據庫,這樣就設計到了切換不同的數據源來進行實現,就比如我們在 Oracle 的數據庫中去查詢一些必要的數據,然后讓這些源頭數據進入到 Mysql ,這個時候,如果不通過第三方的工具,比如 dataWorks或者其他的組件的話, 那么就得通過 Java 代碼來進行實現了,今天了不起就來給大家介紹一下這個關于這個一個注解就切換數據源的操作。jOP28資訊網——每日最新資訊28at.com

數據源

數據源的意思是“數據庫應用程序所使用的數據庫或者數據庫服務器”;數據源也即數據的來源,是提供某種所需要數據的器件或原始媒體,在數據源中存儲了所有建立數據庫連接的信息,通過提供正確的數據源名稱,可以找到相應的數據庫連接。jOP28資訊網——每日最新資訊28at.com

@DS

我們先來看看這個注解的使用jOP28資訊網——每日最新資訊28at.com

<!--配置多數據源-->        <dependency>            <groupId>com.baomidou</groupId>            <artifactId>dynamic-datasource-spring-boot-starter</artifactId>            <version>3.5.0</version>        </dependency>

修改YML 的配置如下jOP28資訊網——每日最新資訊28at.com

datasource:    dynamic:      druid:        initial-size: 5        min-idle: 5        maxActive: 20        # 配置獲取連接等待超時的時間        maxWait: 60000        # 配置間隔多久才進行一次檢測,檢測需要關閉的空閑連接,單位是毫秒        timeBetweenEvictionRunsMillis: 6000        # 配置一個連接在池中最小生存的時間,單位是毫秒        minEvictableIdleTimeMillis: 60000        # 配置一個連接在池中最大生存的時間,單位是毫秒        maxEvictableIdleTimeMillis: 900000        validationQuery: SELECT 1 FROM DUAL        testWhileIdle: true        testOnBorrow: false        testOnReturn: false        # 打開PSCache,并且指定每個連接上PSCache的大小        poolPreparedStatements: true        maxPoolPreparedStatementPerConnectionSize: 20      primary: master #設置默認的數據源或者數據源組,默認值即為master      strict: false #嚴格匹配數據源,默認false. true未匹配到指定數據源時拋異常,false使用默認數據源      datasource:        master:          driver-class-name: com.mysql.cj.jdbc.Driver # 3.2.0開始支持SPI可省略此配置          url: jdbc:mysql://localhost:3306/table1?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf-8&useSSL=false&allowMultiQueries=true&allowPublicKeyRetrieval=true          username: xxxx          password: xxxxx        slave_1:          driver-class-name: com.mysql.cj.jdbc.Driver # 3.2.0開始支持SPI可省略此配置          url: jdbc:mysql://localhost:3306/table2?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf-8&useSSL=false&allowMultiQueries=true&allowPublicKeyRetrieval=true          username: xxxx          password: xxxxx

注意這個 dynamic 一定是我們引入的 mybatis 當中的,這個時候,如果我們去使用這個@DS注解的話,那么就可以去切換數據源,比如我們在配置文件中,配置了 master  還有一個 slave_1 的數據源,那么你在使用的時候,可以這樣,在我們的方法,或者類上面jOP28資訊網——每日最新資訊28at.com

@DS("slave_1")

這個注解,你可以使用在你的方法上面,你也可以使用在你的類上面,(一般是用在mapper、service),使用過該注解的方法即可操作到對應的數據源。既然我們知道怎么去使用這個注解了,那么就得來看看這個源碼的部分了。jOP28資訊網——每日最新資訊28at.com

圖片圖片jOP28資訊網——每日最新資訊28at.com

首先mybatis-plus使用com.baomidou.dynamic.datasource.AbstractRoutingDataSource繼承 AbstractDataSource接管數據源;jOP28資訊網——每日最新資訊28at.com

具體實現類(ctrl+alt+b可以查看抽象類或者的具體實現類)為com.baomidou.dynamic.datasource.DynamicRoutingDataSource。項目初始化調用public synchronized void addDataSource(String ds, DataSource dataSource)加載數據源,數據源存進dataSourceMap中。jOP28資訊網——每日最新資訊28at.com

圖片圖片jOP28資訊網——每日最新資訊28at.com

當我們發送具體的操作請求的時候,進行數據操作時,方法會被com.baomidou.dynamic.datasource.aop.DynamicDataSourceAnnotationInterceptor攔截jOP28資訊網——每日最新資訊28at.com

圖片圖片jOP28資訊網——每日最新資訊28at.com

攔截器首先從被攔截的方法或者類(一般@DS注解用于Service,也可用于Mapper和Controller)上尋找@DS注解,獲取到@DS注解的值后將其存入com.baomidou.dynamic.datasource.toolkit.DynamicDataSourceContextHolder;DynamicDataSourceContextHolder使用ThreadLocal存儲當前線程的數據源名。jOP28資訊網——每日最新資訊28at.com

進行數據操作時,會調用org.springframework.jdbc.datasource.getConnection()方法;jOP28資訊網——每日最新資訊28at.com

getConnection()方法最終調用了com.baomidou.dynamic.datasource.AbstractRoutingDataSource的getConnection()方法;jOP28資訊網——每日最新資訊28at.com

數據操作完成后,方法返回第二步中的攔截器,執行DynamicDataSourceContextHolder.poll();清除掉此次Threadlocal中的數據源,避免影響后續數據操作。jOP28資訊網——每日最新資訊28at.com

但是還有一個問題了,那就是不可在事務中切換數據庫,保證事務需要方法使用同一連接,使用@DS(dataSourceOne)方法調用@DS(dataSourceTwo)無法切換連接,會導致方法報錯。jOP28資訊網——每日最新資訊28at.com

本文鏈接:http://www.www897cc.com/showinfo-26-34656-0.html一個注解搞定多數據源切換,你學會了嗎?

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 不少人面試都掛在這道題了!你掛了嗎?

下一篇: Springboot擴展點之BeanDefinitionRegistryPostProcessor,你學會了嗎?

標簽:
  • 熱門焦點
  • 小米官宣:2023年上半年出貨量中國第一!

    今日早間,小米電視官方微博帶來消息,稱2023年小米電視上半年出貨量達到了中國第一,同時還表示小米電視的巨屏風暴即將開始。“公布一個好消息2023年#小米電視上半年出貨量中國
  • 微信語音大揭秘:為什么禁止轉發?

    大家好,我是你們的小米。今天,我要和大家聊一個有趣的話題:為什么微信語音不可以轉發?這是一個我們經常在日常使用中遇到的問題,也是一個讓很多人好奇的問題。讓我們一起來揭開這
  • 在線圖片編輯器,支持PSD解析、AI摳圖等

    自從我上次分享一個人開發仿造稿定設計的圖片編輯器到現在,不知不覺已過去一年時間了,期間我經歷了裁員失業、面試找工作碰壁,寒冬下一直沒有很好地履行計劃.....這些就放在日
  • 三萬字盤點 Spring 九大核心基礎功能

    大家好,我是三友~~今天來跟大家聊一聊Spring的9大核心基礎功能。話不多說,先上目錄:圖片友情提示,本文過長,建議收藏,嘿嘿嘿!一、資源管理資源管理是Spring的一個核心的基礎功能,不
  • 一個注解實現接口冪等,這樣才優雅!

    場景碼猿慢病云管理系統中其實高并發的場景不是很多,沒有必要每個接口都去考慮并發高的場景,比如添加住院患者的這個接口,具體的業務代碼就不貼了,業務偽代碼如下:圖片上述代碼有
  • 最“俊美”淘寶賣家,靠直播和短視頻圈粉,上架秒光,年銷3000萬

    來源 | 電商在線文|易琬玉編輯|斯問受訪店鋪:Ringdoll戒之人形圖源:微博@御座的黃山、&ldquo;Ringdoll戒之人形&rdquo;淘寶店鋪有關外貌的評價,黃山已經聽累了。生于1985年的他,哪
  • 簽約井川里予、何丹彤,單視頻點贊近千萬,MCN黑馬永恒文希快速崛起!

    來源:視聽觀察永恒文希傳媒作為一家MCN公司,說起它的名字來,可能大家會覺得有點兒陌生,但是說出來下面一串的名字之后,或許大家就會感到震驚,原來這么多網紅,都簽約這家公司了。根
  • 2納米決戰2025

    集微網報道 從三強爭霸到四雄逐鹿,2nm的廝殺聲已然隱約傳來。無論是老牌勁旅臺積電、三星,還是誓言重回先進制程領先地位的英特爾,甚至初成立不久的新
  • 三星Galaxy Z Fold5今日亮相:厚度縮減但仍略顯厚重

    據官方此前宣布,三星將于7月26日也就是今天在韓國首爾舉辦Unpacked活動,屆時將帶來帶來包括Galaxy Buds 3、Galaxy Watch 6、Galaxy Tab S9、Galaxy
Top 主站蜘蛛池模板: 久治县| 乾安县| 甘谷县| 泰顺县| 遵化市| 巴彦县| 荥阳市| 平果县| 漳州市| 武义县| 承德县| 旅游| 正安县| 安阳市| 夏邑县| 全南县| 永春县| 大厂| 贵南县| 平和县| 宜兰市| 万年县| 汕尾市| 南京市| 佛坪县| 丰城市| 景德镇市| 浦县| 姚安县| 林周县| 台中市| 辽源市| 周宁县| 安吉县| 法库县| 抚宁县| 南木林县| 翁牛特旗| 新闻| 宿松县| 嫩江县|