溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

iBATIS的工作原理是什么

發(fā)布時間:2021-07-14 16:27:48 來源:億速云 閱讀:98 作者:chen 欄目:編程語言

本篇內(nèi)容主要講解“iBATIS的工作原理是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“iBATIS的工作原理是什么”吧!

談到iBATIS工作原理問題尤其要注意的是,有了iBATIS,你就再不需要直接編寫JDBC代碼或ADO.NET代碼了。JDBC和ADO.NET的確非常強大,但使用起來總不免覺得太過繁瑣。代碼清單2-2給出了一個使用JDBC的例子。

代碼清單2-2  使用JDBC的代碼示例

iBATIS的工作原理是什么

從這個例子中很容易看出,使用JDBC API編寫代碼需要許多額外的工作。盡管如此,每一行代碼又都是必不可少的,所以要減少代碼量還真不是一件容易的事情。最多也只不過能將其中的一些代碼挪到某個實用方法(utility method)中,最明顯的就是那些關閉資源(如PreparedStatement和ResultSet)的代碼。

對于iBATIS工作原理其實,如果使用iBATIS,iBATIS在后臺也是運行這些相同的JDBC代碼。iBATIS會獲取數(shù)據(jù)庫連接,設置SQL語句的參數(shù),執(zhí)行SQL語句,獲取執(zhí)行結(jié)果,并在***關閉所有的資源。然而,你需要自己親自編寫的代碼量卻大大地減少了。代碼清單2-3給出了使用iBATIS運行相同的SQL語句時你需要編寫的代碼。

代碼清單2-3  iBATIS顯然比JDBC要精簡得多

iBATIS的工作原理是什么

根本無須比較,iBATIS代碼明顯更加簡潔,更容易閱讀,因此也更容易維護。本章稍后會討論更多關于使用iBATIS的好處。但是現(xiàn)在,你最關心的可能是如何用Java代碼運行以上的“SQL語句”。其實就像你在之前的示例中已經(jīng)看到的,運行它僅僅需要一行簡單代碼:

Employee emp = (Employee) sqlMap.queryForObject("getEmployee",new Integer(5));

沒什么好多說的。這行代碼會執(zhí)行相應的SQL語句,設置其參數(shù)并返回一個真實的Java對象作為結(jié)果。SQL語句被“干干凈凈”地封裝在Java代碼之外的一個XML文件中。iBATIS負責管理幕后的所有資源,其運行的實際效果與我們之前所見的代碼清單2-2所示的JDBC的例子是完全一樣的。

這就引起一個問題,iBATIS對所有的系統(tǒng)來說都以一樣的方式工作嗎?或者它僅僅是適用于某一類特定的應用?以下幾節(jié)我們將回答這個問題,首先從iBATIS是多么的適合于小型應用說起。

2.1.iBATIS工作原理之于小型、簡單系統(tǒng)

小型應用通常只涉及一個數(shù)據(jù)庫,只有一些相當簡單的用戶接口和領域模型。它的業(yè)務邏輯層非常簡單,有時對一些簡單的只涉及增查改刪(CRUD:Create, Read, Update, Delete)操作的應用來說甚至根本就不存在業(yè)務邏輯。iBATIS之所以非常適合于小型應用,有3個原因。

***,iBATIS自己就很小并且簡單。它不需要服務器或者其他任何類型的中間件。不需要任何額外的基礎設施(infrastructure)。iBATIS也沒有任何第三方依賴。iBATIS的最簡安裝只需要2個JAR文件,總計不過375KB。除了需要配置一下你的SQL映射文件外,iBATIS不需要進行任何安裝,因此只需要幾分鐘時間你就可以擁有一個可工作的持久層了。

第二,iBATIS不會對現(xiàn)存應用的設計或者數(shù)據(jù)庫結(jié)構(gòu)強加任何影響。因此,如果你有一個小型系統(tǒng),且已經(jīng)部分實現(xiàn)或者甚至已經(jīng)發(fā)布了,則你仍然可以重構(gòu)你的持久層以使用iBATIS,這非常簡單。因為iBATIS很簡單,所以它根本不會使得應用的架構(gòu)過分復雜。而如果使用對象/關系映射工具或者代碼生成工具,因為它們都事先就對應用以及數(shù)據(jù)庫的設計做了某些假設,因此它們不可能對應用的架構(gòu)毫無影響。

***,只要你有過軟件開發(fā)的經(jīng)驗,相信你就不會懷疑,任何一個小軟件都幾乎不可避免地有一天會成長為一個大軟件。所有成功的軟件都有進一步成長的趨勢。這是一件好事,而我們接下來想說的就是,iBATIS同樣非常適合于大型系統(tǒng),它甚至可以擴展以滿足企業(yè)級應用的需要。

2.2 iBATIS工作原理之于大型、企業(yè)級系統(tǒng)

iBATIS就是為企業(yè)級應用而設計的。最重要的是,iBATIS在這個領域比之其他解決方案有著大量的優(yōu)點。iBATIS最初的創(chuàng)建者只有從大型應用到企業(yè)級應用系統(tǒng)的開發(fā)經(jīng)驗。這一類系統(tǒng)通常都涉及不止一個數(shù)據(jù)庫,且所有這些數(shù)據(jù)庫都是不可控的。在***章中我們討論了各種類型的數(shù)據(jù)庫,包括企業(yè)級數(shù)據(jù)庫、私有數(shù)據(jù)庫和遺留數(shù)據(jù)庫。作者創(chuàng)建iBATIS框架一個很重要的原因就是針對這樣的數(shù)據(jù)庫。因此,iBATIS擁有許多使其非常適合于企業(yè)應用環(huán)境的特點。

其實iBATIS適用于大型系統(tǒng)中的***個原因我們已經(jīng)說過了,不過這個原因的確很重要,所以我們還是想再強調(diào)一下:iBATIS沒有對你的數(shù)據(jù)庫模型和對象模型的設計做任何假設。不論你的應用中這兩個模型之間是多么不匹配,iBATIS都能適用。更進一步,iBATIS沒有對你的企業(yè)級應用的架構(gòu)做出任何假設。不論你對數(shù)據(jù)庫是根據(jù)業(yè)務功能縱向劃分,還是按照技術(shù)橫向劃分,iBATIS都允許你高效地處理數(shù)據(jù)并將它們整合到你的面向?qū)ο蟮膽弥腥ァ?/p>

第二點,iBATIS的某些特性使得它能夠非常高效地處理大型數(shù)據(jù)集。iBATIS支持的行處理器(row handler)使得它能夠批處理超大型記錄集,一次一條記錄。iBATIS也支持只獲取某個范圍內(nèi)的結(jié)果,這就使得你可以只獲取那些你當前亟需的數(shù)據(jù)。例如,假設你獲取了10,000條記錄,而你其實只需要其中的第500至600條,那你就可以簡單的僅獲取這些記錄。iBATIS支持驅(qū)動提示使得執(zhí)行這樣的操作非常高效。

***一點,iBATIS允許你用多種方式建立從對象到數(shù)據(jù)庫的映射關系。一個企業(yè)級系統(tǒng)只以一種模式工作的情況是非常少見的。許多企業(yè)級系統(tǒng)需要在白天執(zhí)行事務性的工作,而在晚上執(zhí)行批處理工作。iBATIS允許你將同一個類以多種方式映射,以保證每一種工作都能以***效的方式執(zhí)行。iBATIS同樣支持多種數(shù)據(jù)獲取策略。例如,你可以選擇對某些數(shù)據(jù)進行懶加載,也可以將一個復雜的對象圖只用一條聯(lián)合查詢SQL語句就同時加載完畢,從而避免嚴重的性能問題。

以上所說的這些似乎好像在自我推銷了。那么,既然我們已經(jīng)進入了這種狀態(tài),為何不繼續(xù)深入研究一下你需要使用iBATIS的理由呢?我們會在2.3節(jié)做這件事情。并且為了公平起見,在2.4節(jié)中,我們還會討論一些你不應該使用iBATIS的情況。

到此,相信大家對“iBATIS的工作原理是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關內(nèi)容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI