spring jpa 動(dòng)態(tài)sql SpringData JPA也能寫sql,為什么還要用mybatis?
SpringData JPA也能寫sql,為什么還要用mybatis?在頭條上問這個(gè)問題真是太醉了。。順便說一句,胡說八道太多了。國內(nèi)設(shè)計(jì)理念為表驅(qū)動(dòng)??傊?,邏輯是由數(shù)據(jù)表決定的,實(shí)現(xiàn)是由模型來完成的
SpringData JPA也能寫sql,為什么還要用mybatis?
在頭條上問這個(gè)問題真是太醉了。。順便說一句,胡說八道太多了。
國內(nèi)設(shè)計(jì)理念為表驅(qū)動(dòng)。總之,邏輯是由數(shù)據(jù)表決定的,實(shí)現(xiàn)是由模型來完成的。事實(shí)上,這與面向?qū)ο蟮乃枷虢厝幌喾?。大多?shù)工程師手中所謂的mybatis的靈活性是,他們不需要考慮如何設(shè)計(jì)模型?!辈还茉鯓樱铱梢杂迷鶶QL來解決這個(gè)問題。模型設(shè)計(jì)太差了,只能靠SQL來修正。JPA是完全對(duì)象驅(qū)動(dòng)的思想。早期設(shè)計(jì)的缺陷會(huì)制約后續(xù)的開發(fā),不同的數(shù)據(jù)庫可以用不同的方式實(shí)現(xiàn)(事實(shí)上,即使redis也是一樣的)。回答一些常見的問題。
1. JPA表的連接行為具有不確定性和難以控制性。
您確定使用了spring數(shù)據(jù)JPA嗎?不知道有實(shí)體圖嗎?當(dāng)一個(gè)傻瓜達(dá)到這個(gè)水平時(shí),他能做什么。
2. JPA子查詢不容易實(shí)現(xiàn)。
我想你沒用過,是嗎?spring數(shù)據(jù)JPA的子查詢不僅可以單獨(dú)定義視圖,還可以進(jìn)行子查詢,甚至可以直接使用jpql。
3. JPA不容易優(yōu)化。
我真的不相信99%的優(yōu)化能超過spring data JPA的優(yōu)化。特別是,普通程序員能否停止談?wù)搩?yōu)化?他們甚至搞不懂MySQL的鎖。表設(shè)計(jì)就像一堆廢話,他們?nèi)匀幻刻焓褂迷鶶QL。你覺得他們很棒嗎?JPA可以將表屬性反映到對(duì)象。當(dāng)然,運(yùn)行時(shí)優(yōu)化是有基礎(chǔ)的。ORM的發(fā)展空間太大了。任何有點(diǎn)技術(shù)知識(shí)的人都知道ORM將擁有越來越多的優(yōu)勢(shì)。有一點(diǎn)經(jīng)驗(yàn)的程序員都知道,在談?wù)撈渌酥埃菚r(shí)候先談?wù)摿己玫木S護(hù)了。解決性能問題的方法太多了。
最后,難道你不知道ORM cqrs現(xiàn)在是提倡的嗎?請(qǐng)問,有沒有什么復(fù)雜的問題沒有原生SQL的介入是無法解決的。
jpa原生sql插入數(shù)據(jù),參數(shù)如何設(shè)置?
JPA是面向?qū)ο髷?shù)據(jù)持久化的標(biāo)準(zhǔn)API。要實(shí)現(xiàn)對(duì)象的持久化,首先需要建立JavaBean與關(guān)系數(shù)據(jù)庫之間的映射關(guān)系(使用java注解或XML),然后構(gòu)建/修改JavaBean實(shí)例,調(diào)用JPA相關(guān)接口實(shí)現(xiàn)對(duì)象持久化,相關(guān)SQL操作由JPA底層自動(dòng)完成。有關(guān)詳細(xì)信息,請(qǐng)參閱JPA文檔。
存儲(chǔ)過程含有動(dòng)態(tài)SQL,與靜態(tài)SQL有什么差別?
靜態(tài)SQL是一種SQL,其內(nèi)容是固定和確定的。例如,選擇*from EMP where empno=1。動(dòng)態(tài)SQL主要有兩種,一種是帶參數(shù)的SQL。例如,選擇*from EMP where empno=“一個(gè)變量或輸入值”,也就是說,這個(gè)參數(shù)是一個(gè)變量,而不是一個(gè)固定數(shù)量,即動(dòng)態(tài)SQL。另一種動(dòng)態(tài)SQL是組裝語句的動(dòng)態(tài)SQL,即組裝語句。這種現(xiàn)象經(jīng)常發(fā)生在存儲(chǔ)過程中。例如,如果頁面上有一個(gè)輸入頁面有八個(gè)空格,需要三個(gè)空格,其他空格是可選的,那么這是一個(gè)拼接語句。最簡單的是所有其他字段都為空。也可以根據(jù)輸入的位置判斷語句的具體內(nèi)容。這是一個(gè)拼接語句。