本篇內(nèi)容主要講解“Hibernate ibatis怎么理解”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Hibernate ibatis怎么理解”吧!
創(chuàng)新互聯(lián)建站是一家企業(yè)級云計(jì)算解決方案提供商,超15年IDC數(shù)據(jù)中心運(yùn)營經(jīng)驗(yàn)。主營GPU顯卡服務(wù)器,站群服務(wù)器,移動(dòng)服務(wù)器托管,海外高防服務(wù)器,機(jī)柜大帶寬,動(dòng)態(tài)撥號VPS,海外云手機(jī),海外云服務(wù)器,海外服務(wù)器租用托管等。
使用ibatis需要自己寫SQL時(shí),由于我們的SQL不可能完全符合SQL標(biāo)準(zhǔn),比起Hibernate產(chǎn)生的SQL來,可移植性差。不過由于我們更改 數(shù)據(jù)庫的可能性較小,對我們來說SQL符合標(biāo)準(zhǔn)以便可以在遷移到不同服務(wù)器時(shí)代價(jià)最小并不是十分必要的。另一方面,Hibernate雖然可以屏蔽很多 數(shù)據(jù)庫間的不同,但是卻很難利用某些數(shù)據(jù)庫的高級特性,比如oracle的分析統(tǒng)計(jì)函數(shù)。
Hibernate不適合數(shù)據(jù)庫模式不規(guī)范,約束不完整,需要大量復(fù)雜查詢的系統(tǒng),同時(shí)Hibernate的學(xué)習(xí)成本較高,完全掌握Hibernate也較困難,風(fēng)險(xiǎn)較大。
自己寫框架未必比ibatis的好,穩(wěn)定,強(qiáng)大和可擴(kuò)展。而且自己開發(fā)框架也需要較大的工作量。
如果使用dotnet并且要選一個(gè)數(shù)據(jù)層框架,而系統(tǒng)中有相當(dāng)一部分較復(fù)雜的SQL,或數(shù)據(jù)庫設(shè)計(jì)不合理,臟數(shù)據(jù)多,對性能和資源要求嚴(yán)格,ibatis 是一個(gè)比較不錯(cuò)的選擇。他的那些缺點(diǎn)并不是致命的,而且也是有一些解決方案的。尤其是,當(dāng)選用了ibatis的dataaccess作為dao框架時(shí),我們可以同時(shí)使用Hibernate,ado.net和datamapper(ibatisnet的核心組件),那樣將會(huì)使風(fēng)險(xiǎn)降到***,并且整個(gè)系統(tǒng)的 框架比較合理。
另外,利用ibatis可以統(tǒng)一編碼風(fēng)格,節(jié)約開發(fā)成本,大家不會(huì)再把精力浪費(fèi)到分頁 連接池 主鍵生成等地方了,可以集中精力進(jìn)行業(yè)務(wù)組件的編寫。
綜上: 很多時(shí)候我們要在是自己開發(fā)框架和選用第三方框架和選用什么樣的框架問題上進(jìn)行綜合考慮??紤]的標(biāo)準(zhǔn)當(dāng)然是項(xiàng)目的當(dāng)前情況和我們希望達(dá)到目的的一個(gè)平衡。
ibatis只是封裝了數(shù)據(jù)訪問層,替我們做了部分的對象關(guān)系映射。但我們的代價(jià)是必須要寫xml配置文件,相對于Hibernate我們還要寫很多 SQL.Hibernate通過工具直接從數(shù)據(jù)庫模式生成實(shí)體類和基本的配置文件,而且大部分情況下不需要我們寫SQL,會(huì)較大的提升開發(fā)效率。但這些也 有很多的局限性,尤其是對環(huán)境的要求較高(數(shù)據(jù)庫設(shè)計(jì),對象設(shè)計(jì),團(tuán)隊(duì)的協(xié)作等)。
個(gè)人感覺ibatis對項(xiàng)目比較有意義的地方在于它小巧靈活,可擴(kuò)展,封裝了數(shù)據(jù)訪問層(事務(wù),緩存,異常,日志),并提供了dao框架支持。
利用ibatis我們可以做到代碼和SQL的分離,只要SQL能夠解決的問題,ibatis就能幫我們較容易的解決,同時(shí)也使我們的項(xiàng)目對某一框架的依賴性變?。ㄒ?yàn)閕batis是非侵入性的)。這將極大的降低項(xiàng)目風(fēng)險(xiǎn),減少解決復(fù)雜問題的時(shí)間,使項(xiàng)目的維護(hù)變得簡單。
ibatis對于應(yīng)用的修改,調(diào)試,擴(kuò)充和維護(hù)將會(huì)變得容易自然。修改時(shí),我們主要修改的是代表模型的實(shí)體對象,xml配置文件中的SQL,和/或配置文件的resultmap(很多時(shí)候是不需要的)。同時(shí),SQL和代碼分離,我們不用在代碼的stringbuffer的append方法之間尋找需要修改的SQL.配置文件中的SQL便利了我們的調(diào)試和對SQL的評審及以后的SQL重用。
利用一些框架在前期一般會(huì)拖慢開發(fā)效率。因?yàn)槲覀冃枰冻鰧W(xué)習(xí)成本,很多時(shí)候,使用框架需要寫很多配置文件,在使用不熟時(shí)開發(fā)速度較慢;同時(shí)利用框架往往使系統(tǒng)代碼量增大,比如model1和model2模型,開發(fā)效率應(yīng)該還是model1快,四層的架構(gòu)肯定比兩層的代碼量大。但對于中后期開發(fā)和維護(hù)將會(huì)極大的提高效率。
利用一些較完全的開發(fā)框架和代碼生成工具,在前期會(huì)較大的提高開發(fā)效率,但在后期常常會(huì)拖慢進(jìn)度,并有可能成為以后維護(hù)的夢魘。比如torque生成實(shí)體類和其對應(yīng)的SQL,雖大幅提高了效率,但修改負(fù)擔(dān)較大。
比較理想的開發(fā)方式是使用簡單框架結(jié)合簡單的代碼生成工具??蚣芴峁┫到y(tǒng)的基礎(chǔ)服務(wù),并規(guī)范開發(fā)??蚣芤环矫嫣峁┝碎_發(fā)中某一方面的開發(fā)基礎(chǔ)支持,比如數(shù)據(jù)訪問層,事務(wù),日志,公用類,異常等。另一方面,也為開發(fā)定義了模式,定義了系統(tǒng)的基本輪廓。同時(shí),通過簡單的代碼生成工具生成部分低級的代碼。比如通過工具從數(shù)據(jù)庫模式生成實(shí)體類。這些類生成后我們可以自由修改。
Hibernate是十分強(qiáng)大,比較完善的orm框架,不過這是它的優(yōu)點(diǎn)也是它的缺點(diǎn)。 J2EE系統(tǒng)是否采用Hibernate3,是一個(gè)需要認(rèn)真評估的問題。
要想Hibernate工作的好,數(shù)據(jù)庫的設(shè)計(jì)必須好。同時(shí)對于復(fù)雜的數(shù)據(jù)操作同時(shí)需要使用SQL,Hibernate3對于直接使用SQL的支持比Hibernate2要自然,這一點(diǎn)是可以接受的。
Hibernate比較復(fù)雜,功能強(qiáng)大而靈活,要用好Hibernate確實(shí)不是很簡單,當(dāng)然spring框架提供了對Hibernate的封裝,使Hibernate的使用變得簡單了點(diǎn)。
可以說ibatis在任何系統(tǒng)里都適用,但未必是***選擇。不過ibatis提供的思路是我們應(yīng)該仔細(xì)考慮的。
到此,相信大家對“Hibernate ibatis怎么理解”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!