起因:

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

思路:

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

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

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

困難解決:

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

2、動(dòng)態(tài)數(shù)據(jù)源的切換不能用枚舉來(lái)標(biāo)識(shí),得用常量

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

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

網(wǎng)友評(píng)論