java jdbc執(zhí)行sql語句 SpringData JPA也能寫sql,為什么還要用mybatis?
SpringData JPA也能寫sql,為什么還要用mybatis?在頭條上問這個(gè)問題真是太醉了。。順便說一句,胡說八道太多了。國內(nèi)設(shè)計(jì)理念為表驅(qū)動??傊?,邏輯是由數(shù)據(jù)表決定的,實(shí)現(xiàn)是由模型來完成的
SpringData JPA也能寫sql,為什么還要用mybatis?
在頭條上問這個(gè)問題真是太醉了。。順便說一句,胡說八道太多了。
國內(nèi)設(shè)計(jì)理念為表驅(qū)動。總之,邏輯是由數(shù)據(jù)表決定的,實(shí)現(xiàn)是由模型來完成的。事實(shí)上,這與面向?qū)ο蟮乃枷虢厝幌喾础4蠖鄶?shù)工程師手中所謂的mybatis的靈活性是,他們不需要考慮如何設(shè)計(jì)模型?!辈还茉鯓?,我可以用原生SQL來解決這個(gè)問題。模型設(shè)計(jì)太差了,只能靠SQL來修正。JPA是完全對象驅(qū)動的思想。早期設(shè)計(jì)的缺陷會制約后續(xù)的開發(fā),不同的數(shù)據(jù)庫可以用不同的方式實(shí)現(xiàn)(事實(shí)上,即使redis也是一樣的)?;卮鹨恍┏R姷膯栴}。
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可以將表屬性反映到對象。當(dāng)然,運(yùn)行時(shí)優(yōu)化是有基礎(chǔ)的。ORM的發(fā)展空間太大了。任何有點(diǎn)技術(shù)知識的人都知道ORM將擁有越來越多的優(yōu)勢。有一點(diǎn)經(jīng)驗(yàn)的程序員都知道,在談?wù)撈渌酥埃菚r(shí)候先談?wù)摿己玫木S護(hù)了。解決性能問題的方法太多了。
最后,難道你不知道ORM cqrs現(xiàn)在是提倡的嗎?請問,有沒有什么復(fù)雜的問題沒有原生SQL的介入是無法解決的。
本人本科大二,隨手可以寫java網(wǎng)課上的倉儲系統(tǒng)(無法聯(lián)網(wǎng),圖形化界面,sql),在業(yè)內(nèi)算什么水平呢?
我做軟件已經(jīng)20多年了。編程不僅是關(guān)于使用什么語言,而且是關(guān)于思考。編程語言只是一種工具。如果你熟悉一個(gè)工具,那就沒什么值得驕傲的了,除非你想把編程和詩人比較一下。一個(gè)軟件要實(shí)現(xiàn)哪些功能,這些功能用戶如何使用才能酷、易用、穩(wěn)定如新是最重要的。否則,這是一個(gè)懸而未決的問題,在這個(gè)領(lǐng)域沒有太大的前途
Java可以實(shí)現(xiàn)與大多數(shù)主流數(shù)據(jù)庫的連接和操作。
大多數(shù)日常企業(yè)開發(fā)都使用開源數(shù)據(jù)庫。
1)目前使用最廣泛的數(shù)據(jù)庫是mysql,它具有奇偶校驗(yàn)功能3)PostgreSQL數(shù)據(jù)庫采用經(jīng)典的C/S(client/server)結(jié)構(gòu),即一個(gè)客戶端對應(yīng)一個(gè)服務(wù)器端守護(hù)程序模式。PostgreSQL有一個(gè)完美的驅(qū)動程序,并支持標(biāo)準(zhǔn)的ansi sql和擴(kuò)展函數(shù)
其他高薪產(chǎn)品,如Oracle和sql server。