最近由於諮詢spring如何配置多數據源的人很多,一一回答又比較麻煩,而且以前的博文中的配置也是有問題,因此特此重新發布一個Demo給大家。
Demo中共有兩個資料來源,即MySQL和Oracle,並且已經進行簡單測試,動態切換資料來源是沒有問題的,希望藉此Demo能幫助大家。
另外我給一些說明,闡述下多資料來源配置時的重點:
1. 注意事務攔截器的配置
這是首要的一條。首先你要明白,Spring的事務管理是與資料來源綁定的,一旦程式執行到事務管理的那一層(如service)的話,由於在進入該層之前事務已經通過攔截器開啟,因此在該層切換資料來源是不行的,明白事務的原理是尤為重要的,我之前的文章中,將切換資料來源的攔截器配置在了Dao層是有問題的(因為是範例,所以粗心了,對誤導了大家我表示道歉),但提供的思路是沒有問題的。
Demo中將切換資料來源的攔截器(dataSourceInterceptor)配置在了交易攔截器(txadvice)的上一層,也就是Controller層。
2. 注意資料庫表的建立
一些人喜歡用hibernate的自動建立表的功能,但需要注意,在多資料來源中,尤其是不同資料庫的多資料來源,想都自動建表是不行的。因為Hibernate自動建表是在專案啟動時觸發的,因此只會建立專案配置的預設資料來源的表,而其他資料來源的表則不會自動建立。大家要注意著點。
3. Hibernate的資料庫方言(dialect)可以忽略
在多重資料來源時,方言的設定可以忽略,Hibernate在使用時會自動識別不同的資料庫,因此不必糾結這個配置,甚至不配置也可以。
4. 報No current session錯誤
這個是因為使用了sessionFactory.getCurrentSession()導致的,current session是與線程綁定的,一個線程只會開啟一個Session(除非使用openSession()會報錯),因此需要設定session與執行緒的綁定關係。
Demo中使用了Spring管理Hibernate的session,因此在web.xml中配置了OpenSessionInViewFilter,並在hibernate.cfg.xml中配置了current_session_context_class。 【PS:使用Spring管理Hibernate時,可以去掉hibernate.cfg.xml,而全部配置的Spring的設定檔裡,即hibernateProperties。看個人喜好吧】
最後,Demo中簡單集成了一些框架,方便大家拿來就用,算是送給大家的福利,關於那些框架的配置和技術,這裡就不再闡述了。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持PHP中文網。
更多Spring動態多資料來源配置相關文章請關注PHP中文網!

本文討論了使用Maven和Gradle進行Java項目管理,構建自動化和依賴性解決方案,以比較其方法和優化策略。

本文使用Maven和Gradle之類的工具討論了具有適當的版本控制和依賴關係管理的自定義Java庫(JAR文件)的創建和使用。

本文討論了使用咖啡因和Guava緩存在Java中實施多層緩存以提高應用程序性能。它涵蓋設置,集成和績效優勢,以及配置和驅逐政策管理最佳PRA

本文討論了使用JPA進行對象相關映射,並具有高級功能,例如緩存和懶惰加載。它涵蓋了設置,實體映射和優化性能的最佳實踐,同時突出潛在的陷阱。[159個字符]

Java的類上載涉及使用帶有引導,擴展程序和應用程序類負載器的分層系統加載,鏈接和初始化類。父代授權模型確保首先加載核心類別,從而影響自定義類LOA


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

WebStorm Mac版
好用的JavaScript開發工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中