<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 14,  comments - 37,  trackbacks - 0

    Hibernate

    Hibernate是一個(gè)開放源代碼的對(duì)象關(guān)系映射框架,它對(duì)JDBC進(jìn)行了非常輕量級(jí)的對(duì)象封裝,使得Java程序員可以隨心所欲的使用對(duì)象編程思維來操縱數(shù)據(jù)庫(kù)。Hibernate可以應(yīng)用在任何使用JDBC的場(chǎng)合,既可以在Java的客戶端程序使用,也可以在Servlet/JSPWeb應(yīng)用中使用,最具革命意義的是,Hibernate可以在應(yīng)用EJBJ2EE架構(gòu)中取代CMP,完成數(shù)據(jù)持久化的重任。

    一、      基本功能

    Hibernate作為數(shù)據(jù)持久化的中間件,足以讓數(shù)據(jù)庫(kù)在業(yè)務(wù)邏輯層開發(fā)中去冬眠。它通過可擴(kuò)展標(biāo)記語言(XML)實(shí)現(xiàn)了類和數(shù)據(jù)表之間的映射,使程序員在業(yè)務(wù)邏輯的開發(fā)中面向數(shù)據(jù)庫(kù)而改為面向?qū)ο箝_發(fā)。使整個(gè)項(xiàng)目開發(fā)分工更加明確,提高了程序開發(fā)的效率。

     

    configuration對(duì)象:

    Configuration 類負(fù)責(zé)管理Hibernate 的配置信息。Hibernate 運(yùn)行時(shí)需要
     
    獲取一些底層實(shí)現(xiàn)的基本信息,其中幾個(gè)關(guān)鍵屬性包括:
     1
    數(shù)據(jù)庫(kù)URL
     2
    數(shù)據(jù)庫(kù)用戶

     3
    數(shù)據(jù)庫(kù)用戶密碼
     4
    數(shù)據(jù)庫(kù)JDBC驅(qū)動(dòng)類
     5
    數(shù)據(jù)庫(kù)dialect,用于對(duì)特定數(shù)據(jù)庫(kù)提供支持,其中包含了針對(duì)特定數(shù)據(jù)庫(kù)特性的實(shí)現(xiàn),如Hibernate數(shù)據(jù)類型到特定數(shù)據(jù)庫(kù)數(shù)據(jù)類型的映射等。

    以上信息一般情況下由hibernate.cfg.xml或者hibernate.properties文件來配置,實(shí)現(xiàn)與不同數(shù)據(jù)庫(kù)的連接。

     

    Session對(duì)象:

    Session是持久層操作的基礎(chǔ),相當(dāng)于JDBC中的Connection:
     
    實(shí)例通過SessionFactory實(shí)例構(gòu)建
    :
     
     Configuration config = new Configuration().configure();
     SessionFactory sessionFactory = config.buildSessionFactory();
     Session session = sessionFactory.openSession();
     
     
    之后我們就可以調(diào)用Session所提供的savefindflush等方法完成持久層操作。因此Session對(duì)象也封裝了所有對(duì)數(shù)據(jù)庫(kù)的操作來實(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語句,從而實(shí)現(xiàn)了程序員對(duì)PO對(duì)象的操作轉(zhuǎn)化為對(duì)數(shù)據(jù)庫(kù)關(guān)系表的操作。

    二、使用步驟

    1.編寫Hibernate配置文件

           Hibernate配置文件有兩種,分別是hibernate.cfg.xml文件和hibernate.properties,推薦使用hibernate.cfg.xml

    2PO和映射文件

    使用middlegenhibernate-extensions從數(shù)據(jù)庫(kù)導(dǎo)出PO的映射文件,并在hibernate.cfg.xml當(dāng)中聲明。

    3.編寫DAO

           對(duì)每一張關(guān)系表編寫一個(gè)DAO,提供一組增、刪、改、查方法供業(yè)務(wù)邏輯對(duì)數(shù)據(jù)庫(kù)操作使用。

    Ibatis

    相對(duì)HibernateApache OJB "一站式"ORM解決方案而言,ibatis 是一種"半自動(dòng)化"ORM實(shí)現(xiàn)。所謂"半自動(dòng)",可能理解上有點(diǎn)生澀。縱觀目前主流的ORM,無論Hibernate 還是Apache OJB,都對(duì)數(shù)據(jù)庫(kù)結(jié)構(gòu)提供了較為完整的封裝,提供了從POJO 到數(shù)據(jù)庫(kù)表的全套映射機(jī)制。程序員往往只需定義好了POJO 到數(shù)據(jù)庫(kù)表的映射關(guān)系,即可通過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語句,從而取得更加準(zhǔn)確的數(shù)據(jù),同時(shí)為優(yōu)化查詢、連接查詢提供了方便。

    一、基本功能

    作為又一個(gè)輕量級(jí)的ORM中間件,ibatis除了提供了對(duì)數(shù)據(jù)庫(kù)基本的增、刪、改、查外還提供了連接管理,緩存支持,線程支持,(分布式)事物管理等一套教為完整的數(shù)據(jù)庫(kù)管理功能。

    SqlMapClient對(duì)象是ibatis持久層操作的基礎(chǔ),相當(dāng)于hibernate中的session,提供對(duì)SQL映射的方法。

    insert()方法實(shí)現(xiàn)對(duì)插入SQL語句的映射;

    delete()方法實(shí)現(xiàn)對(duì)刪除SQL語句的映射;

    update()方法實(shí)現(xiàn)對(duì)更新SQL語句的影射;

    queryForList()queryForMap()queryForObject()queryForPaginatedList()等方法提供了一組查詢SQL語句的影射;

    ……

    ……

    二、使用步驟

    1ibatis SQL Map 配置文件

           文件中對(duì)所用數(shù)據(jù)庫(kù)的連接做了基本配置,包括數(shù)據(jù)庫(kù)驅(qū)動(dòng)類型、用戶名、密碼,以及連接池的相關(guān)管理數(shù)據(jù)。

    2PO和映射文件

           hibernate一樣,PO作為數(shù)據(jù)庫(kù)關(guān)系表的影射,也需要響應(yīng)的映射配置文件,可以手寫,也可以借助hibernate的相關(guān)工具生成PO,不會(huì)影響POibatis中的使用。與hibernate不同的是,ibatis的映射文件中沒有對(duì)PO中每個(gè)屬性做響應(yīng)的描述,而是指定了一系列與PO有關(guān)的SQL相關(guān)操作,也體現(xiàn)了ibatis良好的靈活性與可擴(kuò)展性。

    3.編寫DAO

           DAO中,可以使用SqlMapClient提供的方法來對(duì)應(yīng)的指定對(duì)PO操作的SQL語句,從而使業(yè)務(wù)邏輯層的開發(fā)仍然是面向?qū)ο蟮牟僮鳌?/span>

     

    相對(duì)Hibernate“O/R”而言,iBATIS 是一種“Sql Mapping”的ORM實(shí)現(xiàn)。
    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)系,即可通過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ù)庫(kù)移植性上的讓步,為系統(tǒng)設(shè)計(jì)提供了更大的自由空間。
    二者的對(duì)比:1. iBATIS非常簡(jiǎn)單易學(xué),Hibernate相對(duì)較復(fù)雜,門檻較高。2.二者都是比較優(yōu)秀的開源產(chǎn)品3.當(dāng)系統(tǒng)屬于二次開發(fā),無法對(duì)數(shù)據(jù)庫(kù)結(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ù)庫(kù)字段的修改,Hibernate修改的地方很少,而iBATIS要把那些sql mapping的地方一一修改。6.以數(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ì)思路。7. Hibernate現(xiàn)在已經(jīng)是主流O/R Mapping框架,從文檔的豐富性,產(chǎn)品的完善性,版本的開發(fā)速度都要強(qiáng)于iBATIS8.最關(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).鞋合不合適,只有試了才知道.

    選擇Hibernate還是iBATIS都有它的道理:

    Hibernate功能強(qiáng)大,數(shù)據(jù)庫(kù)無關(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)單,需要寫的代碼很少,開發(fā)速度很快,非常爽。

    Hibernate的缺點(diǎn)就是學(xué)習(xí)門檻不低,要精通門檻更高,而且怎么設(shè)計(jì)O/R映射,在性能和對(duì)象模型之間如何權(quán)衡取得平衡,以及怎樣用好Hibernate方面需要你的經(jīng)驗(yàn)和能力都很強(qiáng)才行。

    iBATIS入門簡(jiǎn)單,即學(xué)即用,提供了數(shù)據(jù)庫(kù)查詢的自動(dòng)對(duì)象綁定功能,而且延續(xù)了很好的SQL使用經(jīng)驗(yàn),對(duì)于沒有那么高的對(duì)象模型要求的項(xiàng)目來說,相當(dāng)完美。

    iBATIS的缺點(diǎn)就是框架還是比較簡(jiǎn)陋,功能尚有缺失,雖然簡(jiǎn)化了數(shù)據(jù)綁定代碼,但是整個(gè)底層數(shù)據(jù)庫(kù)查詢實(shí)際還是要自己寫的,工作量也比較大,而且不太容易適應(yīng)快速數(shù)據(jù)庫(kù)修改。

    我的建議就是:

    如果你的團(tuán)隊(duì)沒有Hibernate高手,那么請(qǐng)用iBATIS,要把Hibernate用好,并不容易;否則你應(yīng)該選擇Hibernate,那樣你的開發(fā)速度和代碼簡(jiǎn)潔性都相當(dāng)棒!

    BTW:

    我覺得rails的ActiveRecord是平衡性做的最好的,避免了Hibernate的復(fù)雜性和學(xué)習(xí)HQL的成本,同時(shí)具備iBATIS即學(xué)即用的簡(jiǎn)單性。

    posted on 2007-07-13 14:34 冰封的愛 閱讀(484) 評(píng)論(0)  編輯  收藏 所屬分類: J2EE
    <2025年7月>
    293012345
    6789101112
    13141516171819
    20212223242526
    272829303112
    3456789

    常用鏈接

    留言簿(3)

    隨筆檔案

    文章分類

    文章檔案

    相冊(cè)

    搜索

    •  

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

    主站蜘蛛池模板: 成人免费在线视频| 日本在线高清免费爱做网站| 久久精品国产亚洲av成人| 一级毛片a免费播放王色| 亚洲av无码成人精品区在线播放| 亚洲精品无码你懂的| 在线观看无码的免费网站| 亚洲youwu永久无码精品| 国产福利在线观看永久免费| 亚洲第一福利网站在线观看| 一级做性色a爰片久久毛片免费| 亚洲国产黄在线观看| A毛片毛片看免费| 亚洲av成人无码久久精品| 99精品一区二区免费视频| 亚洲精品中文字幕乱码| 久久不见久久见中文字幕免费| 亚洲日韩一中文字暮| 亚洲国产精品狼友中文久久久 | 在线精品一卡乱码免费| 亚洲乱码国产乱码精华| 青青青国产色视频在线观看国产亚洲欧洲国产综合 | 免费精品人在线二线三线区别| 亚洲日本VA午夜在线影院| 无码国产亚洲日韩国精品视频一区二区三区 | 亚洲人成电影青青在线播放| 国产精品视频永久免费播放| 国产偷国产偷亚洲清高APP| 亚洲日韩中文无码久久| 亚洲一区二区三区免费视频| 亚洲AV无码成人精品区日韩| 国产亚洲精品高清在线| 国产男女爽爽爽爽爽免费视频| 亚洲av无码片vr一区二区三区| 国产成人A亚洲精V品无码 | 亚洲AV无码精品国产成人| 亚洲一区二区三区免费| 麻豆高清免费国产一区| 视频一区在线免费观看| 亚洲经典在线中文字幕| 亚洲国产av无码精品|