成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

選用Ibatis和Hibernate的區(qū)別

開(kāi)發(fā) 后端
選擇hibernate還是選擇ibatis,其實(shí)都有它的道理,本文分別介紹了兩個(gè)的特性,并對(duì)其自身特點(diǎn)和使用特點(diǎn)做了比較。

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的客戶端程序使用,也可以在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)了類和數(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 類負(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或者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.編寫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.編寫dao

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

更多的細(xì)節(jié)請(qǐng)大家參閱hibernate的網(wǎng)站獲取詳細(xì)的信息。并在各自的實(shí)踐和開(kāi)發(fā)中加深體會(huì)。

#p#

ibatis 簡(jiǎn)介

相對(duì)hibernate和apache ojb 等"一站式"orm解決方案而言,ibatis 是一種"半自動(dòng)化"的orm實(shí)現(xiàn)。所謂"半自動(dòng)",可能理解上有點(diǎn)生澀??v觀目前主流的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)化查詢、連接查詢提供了方便。

一、基本功能

作為又一個(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語(yǔ)句的映射;

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

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

queryforlist()、queryformap()、queryforobject()、 queryforpaginatedlist()等方法提供了一組查詢sql語(yǔ)句的影射;

二、使用步驟

1.ibatis sql map 配置文件

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

2.po和映射文件

和hibernate一樣,po作為數(shù)據(jù)庫(kù)關(guān)系表的影射,也需要響應(yīng)的映射配置文件,可以手寫,也可以借助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.編寫dao

在dao中,可以使用sqlmapclient提供的方法來(lái)對(duì)應(yīng)的指定對(duì)po操作的sql語(yǔ)句,從而使業(yè)務(wù)邏輯層的開(kāi)發(fā)仍然是面向?qū)ο蟮牟僮鳌?/p>

#p#

選擇hibernate還是ibatis都有它的道理:

特點(diǎn)對(duì)比

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)單,需要寫的代碼很少,開(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í)門檻不低,要精通門檻更高,而且怎么設(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入門簡(jiǎn)單,即學(xué)即用,提供了數(shù)據(jù)庫(kù)查詢的自動(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ù)查詢實(shí)際還是要自己寫的,工作量也比較大,而且不太容易適應(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需要手寫sql語(yǔ)句,也可以生成一部分,hibernate則基本上可以自動(dòng)生成,偶爾會(huì)寫一些hql。同樣的需求,ibatis的工作量比 hibernate要大很多。類似的,如果涉及到數(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 的話就比較麻煩了,缺省的情況下 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 的話,你又不能把這兩個(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)該差不多??删S護(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 需要程序員編寫,然后通過(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ā)者編寫具體的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 快一些或者很多。

【編輯推薦】

  1. 讓Eclipse使用Vibrant Ink等配色方案
  2. Servlet初始化:隨服務(wù)器啟動(dòng)而運(yùn)行
  3. 如何在Hibernate中使用union
責(zé)任編輯:艾婧 來(lái)源: bd2007的java空間
相關(guān)推薦

2009-09-22 13:12:25

Hibernateibatis

2009-07-15 17:52:10

2009-07-16 16:34:34

iBatis和Hibe

2009-09-24 14:04:25

Hibernate i

2009-09-21 16:56:14

Hibernateibatis

2009-07-17 13:13:47

iBATIS Hibe

2009-07-17 10:08:39

Hibernate與i

2009-07-02 09:25:15

選擇Hibernate

2009-06-29 18:32:30

Hibernate

2009-06-26 16:23:12

Hibernate gHibernate l

2009-06-18 11:43:40

Hibernate uHibernate s

2009-07-20 16:18:54

iBatis分頁(yè)Hibernate式的

2009-06-15 09:57:46

HibernateIBatis

2009-06-12 16:24:44

Hibernate lHibernate g

2009-06-16 15:03:53

Hibernate保存Hibernate

2009-06-24 08:02:15

Hibernateupdate與save

2009-09-28 15:14:45

Hibernate S

2009-07-09 16:01:27

2009-07-21 09:29:27

iBATIS使用

2017-10-26 14:59:47

MybatisHibernate數(shù)據(jù)庫(kù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 粉色午夜视频 | 四虎网站在线观看 | 精品国产乱码久久久久久蜜退臀 | 久久久久久久国产精品视频 | 国产一区在线免费 | 久久久国产精品 | 精品亚洲国产成av人片传媒 | 欧美嘿咻 | 性高朝久久久久久久3小时 av一区二区三区四区 | 亚洲 中文 欧美 日韩 在线观看 | 在线观看一区 | 亚洲一区二区三区视频 | 丁香婷婷久久久综合精品国产 | 搞av.com| 男女久久久| 日本不卡一区二区三区 | 成人欧美一区二区三区白人 | 人人九九精 | 免费在线观看一区二区 | 亚洲激情在线观看 | 免费观看色 | 精品国产乱码久久久久久88av | 精品久久精品 | av片网 | 欧美一区二区三区四区视频 | 亚洲国产精品视频 | 亚洲综合在线播放 | 视频在线观看一区 | 欧美电影在线 | 99re视频在线| 九九热精品免费 | 国产精品久久一区二区三区 | 亚洲欧美视频一区二区 | 中文精品视频 | 国产亚洲成av人片在线观看桃 | 精品一区二区三区免费视频 | 三级特黄特色视频 | 亚洲一区二区在线播放 | 国产一区二区三区在线 | 国产成人在线一区 | 天天爽夜夜操 |