起因:
公司的當(dāng)前產(chǎn)品,主要是兩個(gè)項(xiàng)目集成的,一個(gè)是java項(xiàng)目,還有一個(gè)是php項(xiàng)目,兩個(gè)項(xiàng)目用的是不同的數(shù)據(jù)源,但都是mysql數(shù)據(jù)庫,因?yàn)閖ava這邊的開發(fā)工作已經(jīng)基本完成了,而php那邊任務(wù)還很多,人手也比較緊,產(chǎn)品上線日期緊促,所以領(lǐng)導(dǎo)希望java這邊能夠幫助php那邊寫接口,所以需要切換數(shù)據(jù)源
思路:
動(dòng)態(tài)切換數(shù)據(jù)源確切的來說是在同一類型數(shù)據(jù)庫的情況下的。意思就是說 , 在系統(tǒng)中的使用的數(shù)據(jù)庫分布在多臺數(shù)據(jù)庫服務(wù)器或者在同臺服務(wù)器上的多個(gè)數(shù)據(jù)庫. 在運(yùn)行時(shí)期間根據(jù)某種標(biāo)識符來動(dòng)態(tài)的選擇當(dāng)前操作的數(shù)據(jù)庫.
1.數(shù)據(jù)源是相同類型的數(shù)據(jù)庫: 一個(gè)SessionFactory+動(dòng)態(tài)數(shù)據(jù)源+一個(gè)事務(wù)管理器
2.數(shù)據(jù)源是不同類型的數(shù)據(jù)庫: 根據(jù)類型 配置多套SessionFactory
困難解決:
1、配置dataSource的時(shí)候?qū)d寫成那么,而動(dòng)態(tài)數(shù)據(jù)源的設(shè)置引用的是id
2、動(dòng)態(tài)數(shù)據(jù)源的切換不能用枚舉來標(biāo)識,得用常量
3、在mysql數(shù)據(jù)庫中不同種類的table也照樣起作用
延伸閱讀
- ssh框架 2016-09-30
- 阿里移動(dòng)安全 [無線安全]玩轉(zhuǎn)無線電——不安全的藍(lán)牙鎖 2017-07-26
- 消息隊(duì)列NetMQ 原理分析4-Socket、Session、Option和Pipe 2024-03-26
- Selective Search for Object Recognition 論文筆記【圖片目標(biāo)分割】 2017-07-26
- 詞向量-LRWE模型-更好地識別反義詞同義詞 2017-07-26
- 從棧不平衡問題 理解 calling convention 2017-07-26
- php imagemagick 處理 圖片剪切、壓縮、合并、插入文本、背景色透明 2017-07-26
- Swift實(shí)現(xiàn)JSON轉(zhuǎn)Model - HandyJSON使用講解 2017-07-26
- 阿里移動(dòng)安全 Android端惡意鎖屏勒索應(yīng)用分析 2017-07-26
- 集合結(jié)合數(shù)據(jù)結(jié)構(gòu)來看看(二) 2017-07-26