mybatis多數(shù)據(jù)源切換 mybatis怎么配置兩個(gè)數(shù)據(jù)庫(kù)?
mybatis怎么配置兩個(gè)數(shù)據(jù)庫(kù)?這是我之前編寫(xiě)的代碼的一部分,用于在XML文件中配置Oracle數(shù)據(jù)源。因?yàn)槲沂褂昧朔稚⑴渲?,vaule=的值在另一個(gè)文件中,LZ可以直接硬編碼相關(guān)信息在頭條上問(wèn)這種
mybatis怎么配置兩個(gè)數(shù)據(jù)庫(kù)?
這是我之前編寫(xiě)的代碼的一部分,用于在XML文件中配置Oracle數(shù)據(jù)源。因?yàn)槲沂褂昧朔稚⑴渲?,vaule=的值在另一個(gè)文件中,LZ可以直接硬編碼相關(guān)信息
在頭條上問(wèn)這種問(wèn)題真是醉了。。順便說(shuō)一句,胡說(shuō)八道太多了。
國(guó)內(nèi)設(shè)計(jì)理念為表驅(qū)動(dòng)??傊壿嬍怯蓴?shù)據(jù)表決定的,實(shí)現(xiàn)是由模型來(lái)完成的。事實(shí)上,這與面向?qū)ο蟮乃枷虢厝幌喾?。大多?shù)工程師手中所謂的mybatis的靈活性是,他們不需要考慮如何設(shè)計(jì)模型?!辈还茉鯓樱铱梢杂迷鶶QL來(lái)解決這個(gè)問(wèn)題。模型設(shè)計(jì)太差了,只能靠SQL來(lái)修正。JPA是完全對(duì)象驅(qū)動(dòng)的思想。早期設(shè)計(jì)的缺陷會(huì)制約后續(xù)的開(kāi)發(fā),不同的數(shù)據(jù)庫(kù)可以用不同的方式實(shí)現(xiàn)(事實(shí)上,即使redis也是一樣的)?;卮鹨恍┏R?jiàn)的問(wèn)題。
1. JPA表的連接行為具有不確定性和難以控制性。
您確定使用了spring數(shù)據(jù)JPA嗎?不知道有實(shí)體圖嗎?當(dāng)一個(gè)傻瓜達(dá)到這個(gè)水平時(shí),他能做什么。
2. JPA子查詢不容易實(shí)現(xiàn)。
我想你沒(méi)用過(guò),是嗎?spring數(shù)據(jù)JPA的子查詢不僅可以單獨(dú)定義視圖,還可以進(jìn)行子查詢,甚至可以直接使用jpql。
3. JPA不容易優(yōu)化。
我真的不相信99%的優(yōu)化能超過(guò)spring data JPA的優(yōu)化。特別是,普通程序員能否停止談?wù)搩?yōu)化?他們甚至搞不懂MySQL的鎖。表設(shè)計(jì)就像一堆廢話,他們?nèi)匀幻刻焓褂迷鶶QL。你覺(jué)得他們很棒嗎?JPA可以將表屬性反映到對(duì)象。當(dāng)然,運(yùn)行時(shí)優(yōu)化是有基礎(chǔ)的。ORM的發(fā)展空間太大了。任何有點(diǎn)技術(shù)知識(shí)的人都知道ORM將擁有越來(lái)越多的優(yōu)勢(shì)。有一點(diǎn)經(jīng)驗(yàn)的程序員都知道,在談?wù)撈渌酥?,是時(shí)候先談?wù)摿己玫木S護(hù)了。解決性能問(wèn)題的方法太多了。
最后,難道你不知道ORM cqrs現(xiàn)在是提倡的嗎?請(qǐng)問(wèn),有沒(méi)有什么復(fù)雜的問(wèn)題沒(méi)有原生SQL的介入是無(wú)法解決的。
SpringData JPA也能寫(xiě)sql,為什么還要用mybatis?
這個(gè)問(wèn)題可以從兩個(gè)角度來(lái)回答:
1。批量插入,部分插入失敗,與批量插入的數(shù)據(jù)內(nèi)容無(wú)關(guān)。
例如,在批量插入多個(gè)用戶的情況下。
您可以在邏輯上使用list<>循環(huán)插入。
對(duì)于插入失敗報(bào)告的異常,使用異常處理邏輯將其捕獲并記錄到日志中,或者建立一個(gè)通常未插入的列表<>以供進(jìn)一步處理。
如果發(fā)生大量插入失敗,則需要重新檢查數(shù)據(jù)庫(kù)表和SQL的設(shè)計(jì)。
2. 批插入,部分失敗,與批插入數(shù)據(jù)關(guān)聯(lián)。
例如,插入用戶的訂單、付款、扣減和一系列相關(guān)操作。
建議采用Lucesap提到的事務(wù)處理。如果一個(gè)項(xiàng)目失敗,所有操作都將回滾。為了提高系統(tǒng)的容錯(cuò)率,需要對(duì)設(shè)計(jì)和編碼的合理性進(jìn)行檢查。
個(gè)人意見(jiàn),謝謝!