心的方向

          新的征途......
          posts - 75,comments - 19,trackbacks - 0

          Hibernate??VS? iBATIS

          轉(zhuǎn)之ewolf的工作專欄

          簡介

          Hibernate 是當(dāng)前最流行的 O/R mapping 框架,當(dāng)前版本是 3.05 。它出身于 sf.net ,現(xiàn)在已經(jīng)成為 Jboss 的一部分了

          iBATIS 是另外一種優(yōu)秀的 O/R mapping 框架,當(dāng)前版本是 2.0 。目前屬于 apache 的一個(gè)子項(xiàng)目了。

          相對(duì) Hibernate O/R ”而言, iBATIS 是一種“ Sql Mapping ”的 ORM 實(shí)現(xiàn)。

          Hibernate 對(duì)數(shù)據(jù)庫結(jié)構(gòu)提供了較為完整的封裝, Hibernate O/R Mapping 實(shí)現(xiàn)了 POJO 和數(shù)據(jù)庫表之間的映射,以及 SQL 的自動(dòng)生成和執(zhí)行。程序員往往只需定義好了 POJO 到數(shù)據(jù)庫表的映射關(guān)系,即可通過 Hibernate 提供的方法完成持久層操作。程序員甚至不需要對(duì) SQL 的熟練掌握, Hibernate/OJB 會(huì)根據(jù)制定的存儲(chǔ)邏輯,自動(dòng)生成對(duì)應(yīng)的 SQL 并調(diào)用 JDBC 接口加以執(zhí)行。

          iBATIS 的著力點(diǎn),則在于 POJO SQL 之間的映射關(guān)系。也就是說, iBATIS 并不會(huì)為程序員在運(yùn)行期自動(dòng)生成 SQL 執(zhí)行。具體的 SQL 需要程序員編寫,然后通過映射配置文件,將 SQL 所需的參數(shù),以及返回的結(jié)果字段映射到指定 POJO 。

          使用 iBATIS 提供的 ORM 機(jī)制,對(duì)業(yè)務(wù)邏輯實(shí)現(xiàn)人員而言,面對(duì)的是純粹的 Java 對(duì)象,

          這一層與通過 Hibernate 實(shí)現(xiàn) ORM 而言基本一致,而對(duì)于具體的數(shù)據(jù)操作, Hibernate 會(huì)自動(dòng)生成 SQL 語句,而 iBATIS 則要求開發(fā)者編寫具體的 SQL 語句。相對(duì) Hibernate 而言, iBATIS SQL 開發(fā)的工作量和數(shù)據(jù)庫移植性上的讓步,為系統(tǒng)設(shè)計(jì)提供了更大的自由空間。

          二者的對(duì)比:

          1. ? iBATIS 非常簡單易學(xué), Hibernate 相對(duì)較復(fù)雜,門檻較高。

          2. ? 二者都是比較優(yōu)秀的開源產(chǎn)品

          3. ? 當(dāng)系統(tǒng)屬于二次開發(fā) , 無法對(duì)數(shù)據(jù)庫結(jié)構(gòu)做到控制和修改 , iBATIS 的靈活性將比 Hibernate 更適合

          4. ? 系統(tǒng)數(shù)據(jù)處理量巨大,性能要求極為苛刻,這往往意味著我們必須通過經(jīng)過高度優(yōu)化的 SQL 語句(或存儲(chǔ)過程)才能達(dá)到系統(tǒng)性能設(shè)計(jì)指標(biāo)。在這種情況下 iBATIS 會(huì)有更好的可控性和表現(xiàn)。

          5. ? iBATIS 需要手寫 sql 語句,也可以生成一部分, Hibernate 則基本上可以自動(dòng)生成,偶爾會(huì)寫一些 Hql 。同樣的需求 ,iBATIS 的工作量比 Hibernate 要大很多。類似的,如果涉及到數(shù)據(jù)庫字段的修改, Hibernate 修改的地方很少,而 iBATIS 要把那些 sql mapping 的地方一一修改。

          6. ? 以數(shù)據(jù)庫字段一一對(duì)應(yīng)映射得到的 PO Hibernte 這種對(duì)象化映射得到的 PO 是截然不同的,本質(zhì)區(qū)別在于這種 PO 是扁平化的,不像 Hibernate 映射的 PO 是可以表達(dá)立體的對(duì)象繼承,聚合等等關(guān)系的,這將會(huì)直接影響到你的整個(gè)軟件系統(tǒng)的設(shè)計(jì)思路。

          7. ? Hibernate 現(xiàn)在已經(jīng)是主流 O/R Mapping 框架,從文檔的豐富性,產(chǎn)品的完善性,版本的開發(fā)速度都要強(qiáng)于 iBATIS

          8. ? 最關(guān)鍵的一句話是 iBATIS 的作者說的:

          If you are starting a new project and you're in full control of your object model and database design, Hibernate is a good choice of O/R tool.

          If you are accessing any 3rd party databases (e.g. vendor supplied), or you're working with a legacy database, or even just a really poorly designed database, then an O/R mapper might not be capable of handling the situation. That's were an SQL Mapper comes in handy

          ?

          結(jié)論:

          結(jié)論:

          Hibernate 和iBATIS可以說是互相補(bǔ)充,共同發(fā)展的關(guān)系.具體你想用什么要看實(shí)際情況.如果看了上面的文字還是拿不定注意,那就Just to try it.實(shí)踐是檢驗(yàn)真理的唯一標(biāo)準(zhǔn).鞋合不合適,只有試了才知道



          Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=413018


          文章來源:http://21958978.spaces.live.com/Blog/cns!A7DF246804AD47BB!195.entry
          posted on 2007-03-31 10:49 阿偉 閱讀(211) 評(píng)論(0)  編輯  收藏 所屬分類: J2EE
          主站蜘蛛池模板: 渝中区| 建阳市| 佛教| 嘉定区| 石屏县| 诏安县| 平湖市| 仙桃市| 武义县| 宝应县| 合阳县| 雅安市| 黑山县| 南皮县| 湖北省| 霍城县| 云安县| 瑞昌市| 西城区| 五指山市| 张北县| 湘潭县| 仲巴县| 十堰市| 申扎县| 杂多县| 安溪县| 崇义县| 康定县| 凤冈县| 黄平县| 万山特区| 玉门市| 丰原市| 沾益县| 雷州市| 射阳县| 汽车| 石首市| 康保县| 潞西市|