J2EE 學(xué)習(xí)

          java struts1、struts2 spring hibernate freemarker ajax fckeditor Mysql MSSQL ORACLE DB2 Websphere jboss
          隨筆 - 11, 文章 - 13, 評(píng)論 - 2, 引用 - 0
          數(shù)據(jù)加載中……

          選擇ibatis和hibernate的區(qū)別

          項(xiàng)目中關(guān)于持久層的選擇,我主要有兩種選擇:hibernate與ibatis,各有個(gè)的好,現(xiàn)在總結(jié)如下:
          Hibernate簡(jiǎn)介

          Hibernate是一個(gè)開(kāi)放源代碼的對(duì)象關(guān)系映射框架,它對(duì)JDBC進(jìn)行了非常輕量級(jí)的對(duì)象封裝,使得Java程序員可以隨心所欲的使用對(duì)象編程思維來(lái)操縱數(shù)據(jù)庫(kù)。Hibernate可以應(yīng)用在任何使用JDBC的場(chǎng)合,既可以在Java的客戶(hù)端程序使用,也可以在Servlet/JSP的Web應(yīng)用中使用,最具革命意義的是,Hibernate可以在應(yīng)用EJB的J2EE架構(gòu)中取代CMP,完成數(shù)據(jù)持久化的重任。
          一、基本功能
          Hibernate作為數(shù)據(jù)持久化的中間件,足以讓數(shù)據(jù)庫(kù)在業(yè)務(wù)邏輯層開(kāi)發(fā)中去冬眠。它通過(guò)可擴(kuò)展標(biāo)記語(yǔ)言(XML)實(shí)現(xiàn)了類(lèi)和數(shù)據(jù)表之間的映射,使程序員在業(yè)務(wù)邏輯的開(kāi)發(fā)中面向數(shù)據(jù)庫(kù)而改為面向?qū)ο箝_(kāi)發(fā)。使整個(gè)項(xiàng)目開(kāi)發(fā)分工更加明確,提高了程序開(kāi)發(fā)的效率。
          configuration對(duì)象:
          Configuration?類(lèi)負(fù)責(zé)管理Hibernate?的配置信息。Hibernate?運(yùn)行時(shí)需要
          獲取一些底層實(shí)現(xiàn)的基本信息,其中幾個(gè)關(guān)鍵屬性包括:
          1.?數(shù)據(jù)庫(kù)URL
          2.?數(shù)據(jù)庫(kù)用戶(hù)
          3.?數(shù)據(jù)庫(kù)用戶(hù)密碼
          4.?數(shù)據(jù)庫(kù)JDBC驅(qū)動(dòng)類(lèi)
          5.?dāng)?shù)據(jù)庫(kù)dialect,用于對(duì)特定數(shù)據(jù)庫(kù)提供支持,其中包含了針對(duì)特定數(shù)據(jù)庫(kù)特性的實(shí)現(xiàn),如Hibernate數(shù)據(jù)類(lèi)型到特定數(shù)據(jù)庫(kù)數(shù)據(jù)類(lèi)型的映射等。
          以上信息一般情況下由hibernate.cfg.xml或者h(yuǎn)ibernate.properties文件來(lái)配置,實(shí)現(xiàn)與不同數(shù)據(jù)庫(kù)的連接。
          Session對(duì)象:
          Session是持久層操作的基礎(chǔ),相當(dāng)于JDBC中的Connection:
          實(shí)例通過(guò)SessionFactory實(shí)例構(gòu)建:
          Configuration?config?=?new?Configuration().configure();
          SessionFactory?sessionFactory?=?config.buildSessionFactory();
          Session?session?=?sessionFactory.openSession();
          之后我們就可以調(diào)用Session所提供的save、find、flush等方法完成持久層操作。因此Session對(duì)象也封裝了所有對(duì)數(shù)據(jù)庫(kù)的操作來(lái)實(shí)現(xiàn)Hibernate對(duì)數(shù)據(jù)庫(kù)的操縱功能,如:
          Save()方法實(shí)現(xiàn)增加和保存;
          Delete()方法實(shí)現(xiàn)數(shù)據(jù)的刪除;
          Update()方法實(shí)現(xiàn)數(shù)據(jù)更新和修改;
          Find()方法實(shí)現(xiàn)數(shù)據(jù)的檢索;
          Hibernate會(huì)根據(jù)不同的操作自動(dòng)生成相應(yīng)的SQL語(yǔ)句,從而實(shí)現(xiàn)了程序員對(duì)PO對(duì)象的操作轉(zhuǎn)化為對(duì)數(shù)據(jù)庫(kù)關(guān)系表的操作。
          二、使用步驟
          1.編寫(xiě)Hibernate配置文件
          ???????Hibernate配置文件有兩種,分別是hibernate.cfg.xml文件和hibernate.properties,推薦使用hibernate.cfg.xml。
          2.PO和映射文件
          使用middlegen和hibernate-extensions從數(shù)據(jù)庫(kù)導(dǎo)出PO的映射文件,并在hibernate.cfg.xml當(dāng)中聲明。
          3.編寫(xiě)DAO
          ???????對(duì)每一張關(guān)系表編寫(xiě)一個(gè)DAO,提供一組增、刪、改、查方法供業(yè)務(wù)邏輯對(duì)數(shù)據(jù)庫(kù)操作使用。

          Ibatis簡(jiǎn)介
          相對(duì)Hibernate和Apache?OJB?等"一站式"ORM解決方案而言,ibatis?是一種"半自動(dòng)化"的ORM實(shí)現(xiàn)。所謂"半自動(dòng)",可能理解上有點(diǎn)生澀。縱觀目前主流的ORM,無(wú)論Hibernate?還是Apache?OJB,都對(duì)數(shù)據(jù)庫(kù)結(jié)構(gòu)提供了較為完整的封裝,提供了從POJO?到數(shù)據(jù)庫(kù)表的全套映射機(jī)制。程序員往往只需定義好了POJO?到數(shù)據(jù)庫(kù)表的映射關(guān)系,即可通過(guò)Hibernate或者OJB?提供的方法完成持久層操作。程序員甚至不需要對(duì)SQL?的熟練掌握,Hibernate/OJB?會(huì)根據(jù)制定的存儲(chǔ)邏輯,自動(dòng)生成對(duì)應(yīng)的SQL?并調(diào)用JDBC?接口加以執(zhí)行。
          Ibatis最直接的好處就是不但為程序員提供了對(duì)象與關(guān)系數(shù)據(jù)庫(kù)之間的映射,同時(shí)提供操作方法與SQL間的直接影射,設(shè)計(jì)者可以直接為一個(gè)方法指定一條SQL語(yǔ)句,從而取得更加準(zhǔn)確的數(shù)據(jù),同時(shí)為優(yōu)化查詢(xún)、連接查詢(xún)提供了方便。
          一、基本功能
          作為又一個(gè)輕量級(jí)的ORM中間件,ibatis除了提供了對(duì)數(shù)據(jù)庫(kù)基本的增、刪、改、查外還提供了連接管理,緩存支持,線(xiàn)程支持,(分布式)事物管理等一套教為完整的數(shù)據(jù)庫(kù)管理功能。
          SqlMapClient對(duì)象是ibatis持久層操作的基礎(chǔ),相當(dāng)于hibernate中的session,提供對(duì)SQL映射的方法。
          insert()方法實(shí)現(xiàn)對(duì)插入SQL語(yǔ)句的映射;
          delete()方法實(shí)現(xiàn)對(duì)刪除SQL語(yǔ)句的映射;
          update()方法實(shí)現(xiàn)對(duì)更新SQL語(yǔ)句的影射;
          queryForList()、queryForMap()、queryForObject()、queryForPaginatedList()等方法提供了一組查詢(xún)SQL語(yǔ)句的影射;
          二、使用步驟
          1.ibatis?SQL?Map?配置文件
          ???????文件中對(duì)所用數(shù)據(jù)庫(kù)的連接做了基本配置,包括數(shù)據(jù)庫(kù)驅(qū)動(dòng)類(lèi)型、用戶(hù)名、密碼,以及連接池的相關(guān)管理數(shù)據(jù)。
          2.PO和映射文件
          ???????和hibernate一樣,PO作為數(shù)據(jù)庫(kù)關(guān)系表的影射,也需要響應(yīng)的映射配置文件,可以手寫(xiě),也可以借助hibernate的相關(guān)工具生成PO,不會(huì)影響PO在ibatis中的使用。與hibernate不同的是,ibatis的映射文件中沒(méi)有對(duì)PO中每個(gè)屬性做響應(yīng)的描述,而是指定了一系列與PO有關(guān)的SQL相關(guān)操作,也體現(xiàn)了ibatis良好的靈活性與可擴(kuò)展性。
          3.編寫(xiě)DAO
          ???????在DAO中,可以使用SqlMapClient提供的方法來(lái)對(duì)應(yīng)的指定對(duì)PO操作的SQL語(yǔ)句,從而使業(yè)務(wù)邏輯層的開(kāi)發(fā)仍然是面向?qū)ο蟮牟僮鳌?/span>

          選擇Hibernate還是iBATIS都有它的道理:
          Hibernate的特點(diǎn):
          Hibernate功能強(qiáng)大,數(shù)據(jù)庫(kù)無(wú)關(guān)性好,O/R映射能力強(qiáng),如果你對(duì)Hibernate相當(dāng)精通,而且對(duì)Hibernate進(jìn)行了適當(dāng)?shù)姆庋b,那么你的項(xiàng)目整個(gè)持久層代碼會(huì)相當(dāng)簡(jiǎn)單,需要寫(xiě)的代碼很少,開(kāi)發(fā)速度很快,非常爽。以數(shù)據(jù)庫(kù)字段一一對(duì)應(yīng)映射得到的PO和Hibernte這種對(duì)象化映射得到的PO是截然不同的,本質(zhì)區(qū)別在于這種PO是扁平化的,不像Hibernate映射的PO是可以表達(dá)立體的對(duì)象繼承,聚合等等關(guān)系的,這將會(huì)直接影響到你的整個(gè)軟件系統(tǒng)的設(shè)計(jì)思路。Hibernate對(duì)數(shù)據(jù)庫(kù)結(jié)構(gòu)提供了較為完整的封裝,Hibernate的O/R?Mapping實(shí)現(xiàn)了POJO?和數(shù)據(jù)庫(kù)表之間的映射,以及SQL?的自動(dòng)生成和執(zhí)行。程序員往往只需定義好了POJO?到數(shù)據(jù)庫(kù)表的映射關(guān)系,即可通過(guò)Hibernate?提供的方法完成持久層操作。程序員甚至不需要對(duì)SQL?的熟練掌握,?Hibernate/OJB?會(huì)根據(jù)制定的存儲(chǔ)邏輯,自動(dòng)生成對(duì)應(yīng)的SQL?并調(diào)用JDBC?接口加以執(zhí)行。Hibernate的缺點(diǎn)就是學(xué)習(xí)門(mén)檻不低,要精通門(mén)檻更高,而且怎么設(shè)計(jì)O/R映射,在性能和對(duì)象模型之間如何權(quán)衡取得平衡,以及怎樣用好Hibernate方面需要你的經(jīng)驗(yàn)和能力都很強(qiáng)才行,但是Hibernate現(xiàn)在已經(jīng)是主流O/R?Mapping框架,從文檔的豐富性,產(chǎn)品的完善性,版本的開(kāi)發(fā)速度都要強(qiáng)于iBATIS。
          iBATIS的特點(diǎn):
          iBATIS入門(mén)簡(jiǎn)單,即學(xué)即用,提供了數(shù)據(jù)庫(kù)查詢(xún)的自動(dòng)對(duì)象綁定功能,而且延續(xù)了很好的SQL使用經(jīng)驗(yàn),對(duì)于沒(méi)有那么高的對(duì)象模型要求的項(xiàng)目來(lái)說(shuō),相當(dāng)完美。iBATIS的缺點(diǎn)就是框架還是比較簡(jiǎn)陋,功能尚有缺失,雖然簡(jiǎn)化了數(shù)據(jù)綁定代碼,但是整個(gè)底層數(shù)據(jù)庫(kù)查詢(xún)實(shí)際還是要自己寫(xiě)的,工作量也比較大,而且不太容易適應(yīng)快速數(shù)據(jù)庫(kù)修改。當(dāng)系統(tǒng)屬于二次開(kāi)發(fā),無(wú)法對(duì)數(shù)據(jù)庫(kù)結(jié)構(gòu)做到控制和修改,那iBATIS的靈活性將比Hibernate更適合。系統(tǒng)數(shù)據(jù)處理量巨大,性能要求極為苛刻,這往往意味著我們必須通過(guò)經(jīng)過(guò)高度優(yōu)化的SQL語(yǔ)句(或存儲(chǔ)過(guò)程)才能達(dá)到系統(tǒng)性能設(shè)計(jì)指標(biāo)。在這種情況下iBATIS會(huì)有更好的可控性和表現(xiàn)。
          對(duì)于實(shí)際的開(kāi)發(fā)進(jìn)行的比較:
          1.?iBATIS需要手寫(xiě)sql語(yǔ)句,也可以生成一部分,Hibernate則基本上可以自動(dòng)生成,偶爾會(huì)寫(xiě)一些Hql。同樣的需求,iBATIS的工作量比?Hibernate要大很多。類(lèi)似的,如果涉及到數(shù)據(jù)庫(kù)字段的修改,Hibernate修改的地方很少,而iBATIS要把那些sql?mapping的地方一一修改。
          2.?iBatis?可以進(jìn)行細(xì)粒度的優(yōu)化
          比如說(shuō)我有一個(gè)表,這個(gè)表有幾個(gè)或者幾十個(gè)字段,我需要更新其中的一個(gè)字段,iBatis?很簡(jiǎn)單,執(zhí)行一個(gè)sql?UPDATE?TABLE_A?SET?column_1=#column_1#?WHERE?id=#id#?但是用?Hibernate?的話(huà)就比較麻煩了,缺省的情況下?hibernate?會(huì)更新所有字段。?當(dāng)然我記得?hibernate?有一個(gè)選項(xiàng)可以控制只保存修改過(guò)的字段,但是我不太確定這個(gè)功能的負(fù)面效果。
          例如:我需要列出一個(gè)表的部分內(nèi)容,用?iBatis?的時(shí)候,這里面的好處是可以少?gòu)臄?shù)據(jù)庫(kù)讀很多數(shù)據(jù),節(jié)省流量SELECT?ID,?NAME?FROM?TABLE_WITH_A_LOT_OF_COLUMN?WHERE?...一般情況下Hibernate?會(huì)把所有的字段都選出來(lái)。比如說(shuō)有一個(gè)上面表有8個(gè)字段,其中有一兩個(gè)比較大的字段,varchar(255)/text。上面的場(chǎng)景中我為什么要把他們也選出來(lái)呢?用hibernate?的話(huà),你又不能把這兩個(gè)不需要的字段設(shè)置為lazy?load,因?yàn)檫€有很多地方需要一次把整個(gè)?domain?object?加載出來(lái)。這個(gè)時(shí)候就能顯現(xiàn)出ibatis?的好處了。如果我需要更新一條記錄(一個(gè)對(duì)象),如果使用?hibernate,需要現(xiàn)把對(duì)象?select?出來(lái),然后再做?update。這對(duì)數(shù)據(jù)庫(kù)來(lái)說(shuō)就是兩條sql。而iBatis只需要一條update的sql就可以了。減少一次與數(shù)據(jù)庫(kù)的交互,對(duì)于性能的提升是非常重要。
          3.?開(kāi)發(fā)方面:
          開(kāi)發(fā)效率上,我覺(jué)得兩者應(yīng)該差不多。可維護(hù)性方面,我覺(jué)得?iBatis?更好一些。因?yàn)?iBatis?的?sql?都保存到單獨(dú)的文件中。而?Hibernate?在有些情況下可能會(huì)在?java?代碼中保sql/hql。相對(duì)Hibernate“O/R”而言,iBATIS?是一種“Sql?Mapping”的ORM實(shí)現(xiàn)。而iBATIS?的著力點(diǎn),則在于POJO?與SQL之間的映射關(guān)系。也就是說(shuō),iBATIS并不會(huì)為程序員在運(yùn)行期自動(dòng)生成SQL?執(zhí)行。具體的SQL?需要程序員編寫(xiě),然后通過(guò)映射配置文件,將SQL所需的參數(shù),以及返回的結(jié)果字段映射到指定POJO。使用iBATIS?提供的ORM機(jī)制,對(duì)業(yè)務(wù)邏輯實(shí)現(xiàn)人員而言,面對(duì)的是純粹的Java對(duì)象,這一層與通過(guò)Hibernate?實(shí)現(xiàn)ORM?而言基本一致,而對(duì)于具體的數(shù)據(jù)操作,Hibernate會(huì)自動(dòng)生成SQL?語(yǔ)句,而iBATIS?則要求開(kāi)發(fā)者編寫(xiě)具體的SQL?語(yǔ)句。相對(duì)Hibernate而言,iBATIS?以SQL開(kāi)發(fā)的工作量和數(shù)據(jù)庫(kù)移植性上的讓步,為系統(tǒng)設(shè)計(jì)提供了更大的自由空間。
          4.?運(yùn)行效率
          在不考慮?cache?的情況下,iBatis?應(yīng)該會(huì)比hibernate?快一些或者很多。

          posted on 2009-07-28 21:35 李峰 閱讀(435) 評(píng)論(0)  編輯  收藏 所屬分類(lèi): j2ee

          主站蜘蛛池模板: 阳新县| 安化县| 祁门县| 班玛县| 砚山县| 伊金霍洛旗| 松滋市| 渭源县| 蛟河市| 湘乡市| 云浮市| 美姑县| 宜兰市| 中阳县| 汾阳市| 晋城| 巴楚县| 永宁县| 河曲县| 神木县| 京山县| 金湖县| 乌兰县| 习水县| 奉化市| 和田市| 柘荣县| 湄潭县| 明水县| 綦江县| 军事| 明光市| 沂水县| 达孜县| 手机| 巴林右旗| 蒲城县| 南投市| 敦煌市| 微博| 通道|