mybatis為什么比jdbc快 JAVA實(shí)習(xí)生需要懂spring和mybatis的底層嗎?
JAVA實(shí)習(xí)生需要懂spring和mybatis的底層嗎?對(duì)于大多數(shù)公司來(lái)說(shuō),沒(méi)有時(shí)間和金錢(qián)來(lái)構(gòu)建輪子,所以他們通常使用現(xiàn)成的框架來(lái)開(kāi)發(fā)項(xiàng)目系統(tǒng),因?yàn)榭蚣艿膬?yōu)點(diǎn)是完成大部分的基礎(chǔ)工作,只要他們專注于業(yè)
JAVA實(shí)習(xí)生需要懂spring和mybatis的底層嗎?
對(duì)于大多數(shù)公司來(lái)說(shuō),沒(méi)有時(shí)間和金錢(qián)來(lái)構(gòu)建輪子,所以他們通常使用現(xiàn)成的框架來(lái)開(kāi)發(fā)項(xiàng)目系統(tǒng),因?yàn)榭蚣艿膬?yōu)點(diǎn)是完成大部分的基礎(chǔ)工作,只要他們專注于業(yè)務(wù)代碼的開(kāi)發(fā)。
Spring和mybatis框架,一個(gè)提高了業(yè)務(wù)代碼的耦合度,另一個(gè)封裝了JDBC的基本操作。對(duì)于一個(gè)普通公司的實(shí)習(xí)生來(lái)說(shuō),使用這兩個(gè)框架是可以的,而不是理解基本原則。
但是如果你想在一家大公司實(shí)習(xí),這兩個(gè)框架不僅需要能夠使用,還需要了解某些基本原則,比如spring的IOC和di是如何實(shí)現(xiàn)的,循環(huán)依賴是如何解決的?例如,mybatis的mapper文件是如何加載的,模型是如何與數(shù)據(jù)庫(kù)表相關(guān)聯(lián)的?
您不需要理解所有這些問(wèn)題,但您需要給出一個(gè)大致的想法。當(dāng)然,除了這些,大公司也會(huì)問(wèn)一些非編程語(yǔ)言的問(wèn)題,比如七層網(wǎng)絡(luò)協(xié)議、bio、NiO等,為什么大公司需要你知道這么多?因?yàn)樘嗳讼脒M(jìn)入一家大公司,如果你只知道一些基本的用途,對(duì)原則一無(wú)所知,他們?yōu)槭裁磿?huì)選擇你呢?
想學(xué)mybatis,我需要先詳細(xì)看看jdbc嗎?
首先了解mybatis,然后了解JDBC。
Mybatis是java開(kāi)發(fā)中常用的持久性框架。本質(zhì)上,它是JDBC的封裝。它封裝了大量繁瑣而冗余的過(guò)程,如注冊(cè)驅(qū)動(dòng)程序、創(chuàng)建連接、異常回滾、關(guān)閉連接等。開(kāi)發(fā)人員只需要關(guān)注SQL本身,這大大提高了生產(chǎn)率。
首先學(xué)習(xí)簡(jiǎn)單易用的mybatis框架。當(dāng)你能熟練地使用mybatis時(shí),你自然會(huì)接觸到更多的應(yīng)用場(chǎng)景。根據(jù)實(shí)際需要學(xué)習(xí)JDBC會(huì)事半功倍。
例如,您會(huì)發(fā)現(xiàn)mybatis不能很好地支持大規(guī)模操作的業(yè)務(wù)場(chǎng)景,但是JDBC更適合這種場(chǎng)景。您可能想知道為什么JDBC更好地支持大規(guī)模操作?此時(shí),您將自然地了解更多關(guān)于JDBC的信息。
學(xué)習(xí)是一個(gè)需要不斷積極反饋的過(guò)程。你一上來(lái)就很難學(xué)。很容易打擊你的自信,但這是不值得的損失。
因此,我建議您首先在實(shí)踐中學(xué)習(xí)如何使用mybatis框架和項(xiàng)目;當(dāng)業(yè)務(wù)需要使用JDBC時(shí),您自然會(huì)對(duì)JDBC有更多的了解,而且您不必一開(kāi)始就強(qiáng)制使用。
SpringData JPA也能寫(xiě)sql,為什么還要用mybatis?
在頭條上問(wèn)這個(gè)問(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ù)撈渌酥埃菚r(shí)候先談?wù)摿己玫木S護(hù)了。解決性能問(wèn)題的方法太多了。
最后,難道你不知道ORM cqrs現(xiàn)在是提倡的嗎?請(qǐng)問(wèn),有沒(méi)有什么復(fù)雜的問(wèn)題沒(méi)有原生SQL的介入是無(wú)法解決的。
程序員常說(shuō)的底層是指什么?
當(dāng)我們現(xiàn)在開(kāi)發(fā)軟件時(shí),有許多種類的庫(kù)或組件可以被引用。這將提高軟件開(kāi)發(fā)的效率,當(dāng)然也降低了開(kāi)發(fā)的難度。
它通常指“本機(jī)開(kāi)發(fā)”,即不使用或使用其他人封裝的較少代碼庫(kù)的軟件開(kāi)發(fā)
!例如,對(duì)于Windows應(yīng)用程序的開(kāi)發(fā),使用Visual C或C#,它們對(duì)系統(tǒng)的具體實(shí)現(xiàn)有很多封裝。對(duì)于開(kāi)發(fā)人員來(lái)說(shuō),它是透明的,他們不知道它的具體實(shí)現(xiàn)過(guò)程是怎樣的。
但是如果使用Windows系統(tǒng)提供的原始API進(jìn)行開(kāi)發(fā),則需要掌握系統(tǒng)的具體實(shí)現(xiàn)過(guò)程,了解其原理,才能進(jìn)行軟件開(kāi)發(fā)。而這是提高一個(gè)人系統(tǒng)開(kāi)發(fā)能力的最佳途徑
!因此,作為一名專業(yè)軟件開(kāi)發(fā)人員,我們應(yīng)該從所謂的“底層”了解系統(tǒng)的工作原理。這樣,我們?cè)陂_(kāi)發(fā)軟件時(shí),就可以利用它對(duì)代碼進(jìn)行改進(jìn)和優(yōu)化,提高軟件的效率和健壯性。而不是僅僅能夠?qū)崿F(xiàn)特定的功能,而不關(guān)心軟件的實(shí)現(xiàn)效率等問(wèn)題。
當(dāng)我們熟練地掌握這些“底層”原則時(shí),我們將在軟件開(kāi)發(fā)過(guò)程中更加得心應(yīng)手。只有這樣,所開(kāi)發(fā)的軟件才能更加健壯和可維護(hù)
!如果你認(rèn)為我的回答對(duì)你有幫助,請(qǐng)喜歡。謝謝您
mybatis和jdbc的區(qū)別?
1. Dao層代碼可以通過(guò)現(xiàn)有的插件直接生成,大大提高了編碼效率和準(zhǔn)確性(與手工編碼錯(cuò)誤等相比)。mybatis現(xiàn)有的連接池管理和緩存管理帶來(lái)的代碼性能優(yōu)勢(shì)和可靠性(作為一個(gè)工業(yè)開(kāi)源框架,其代碼已經(jīng)過(guò)了很長(zhǎng)時(shí)間的測(cè)試)。一致的編碼風(fēng)格大大減少了代碼差距4。Mybatis自動(dòng)提供一級(jí)和二級(jí)緩存(需要配置和打開(kāi))、強(qiáng)大的動(dòng)態(tài)SQL和自動(dòng)會(huì)話管理,比手工維護(hù)更方便、更安全。5面向?qū)ο箝_(kāi)發(fā)的效率會(huì)更高。畢竟,它可以自動(dòng)生成數(shù)據(jù)庫(kù)表的模型對(duì)象,編寫(xiě)更少的基本SQL。無(wú)論是否是團(tuán)隊(duì)合作,都建議使用。6不要重復(fù)從結(jié)果集到域的轉(zhuǎn)換。7如果JDBC想擁有自己的mybatis關(guān)聯(lián)和集合,那么您將擁有一個(gè)大腦袋