起因:

公司的當前產(chǎn)品,主要是兩個項目集成的,一個是java項目,還有一個是php項目,兩個項目用的是不同的數(shù)據(jù)源,但都是mysql數(shù)據(jù)庫,因為java這邊的開發(fā)工作已經(jīng)基本完成了,而php那邊任務還很多,人手也比較緊,產(chǎn)品上線日期緊促,所以領導希望java這邊能夠幫助php那邊寫接口,所以需要切換數(shù)據(jù)源

思路:

動態(tài)切換數(shù)據(jù)源確切的來說是在同一類型數(shù)據(jù)庫的情況下的。意思就是說 , 在系統(tǒng)中的使用的數(shù)據(jù)庫分布在多臺數(shù)據(jù)庫服務器或者在同臺服務器上的多個數(shù)據(jù)庫. 在運行時期間根據(jù)某種標識符來動態(tài)的選擇當前操作的數(shù)據(jù)庫.

     1.數(shù)據(jù)源是相同類型的數(shù)據(jù)庫: 一個SessionFactory+動態(tài)數(shù)據(jù)源+一個事務管理器

     2.數(shù)據(jù)源是不同類型的數(shù)據(jù)庫: 根據(jù)類型 配置多套SessionFactory

困難解決:

1、配置dataSource的時候?qū)d寫成那么,而動態(tài)數(shù)據(jù)源的設置引用的是id

2、動態(tài)數(shù)據(jù)源的切換不能用枚舉來標識,得用常量

3、在mysql數(shù)據(jù)庫中不同種類的table也照樣起作用

4、spring的事務處理可能會影響動態(tài)數(shù)據(jù)源的切換(尚未發(fā)現(xiàn)該問題)

延伸閱讀

學習是年輕人改變自己的最好方式-Java培訓,做最負責任的教育,學習改變命運,軟件學習,再就業(yè),大學生如何就業(yè),幫大學生找到好工作,lphotoshop培訓,電腦培訓,電腦維修培訓,移動軟件開發(fā)培訓,網(wǎng)站設計培訓,網(wǎng)站建設培訓學習是年輕人改變自己的最好方式