淺談Mybatis框架的作用與原理

什么是Mybatis?其實(shí)MyBatis 本是apache的一個(gè)開(kāi)源項(xiàng)目iBatis, 2010年這個(gè)項(xiàng)目由apache software foundation 遷移到了google code,并且改名為MyBatis 。iBATIS一詞來(lái)源于“internet”和“abatis”的組合,是一個(gè)基于Java的持久層框架。iBATIS提供的持久層框架包括SQL Maps和Data Access Objects(DAO)。

下面來(lái)看一下官網(wǎng)對(duì)Mybatis的介紹吧:MyBatis 是支持定制化 SQL、存儲(chǔ)過(guò)程以及高級(jí)映射的優(yōu)秀的持久層框架。MyBatis 避免了幾乎所有的 JDBC 代碼和手工設(shè)置參數(shù)以及抽取結(jié)果集。MyBatis 使用簡(jiǎn)單的 XML 或注解來(lái)配置和映射基本體,將接口和 Java 的POJOs(Plain Old Java Objects,普通的 Java對(duì)象)映射成數(shù)據(jù)庫(kù)中的記錄。

MyBatis是iBatis的升級(jí)版,用法有很多的相似之處,但是MyBatis進(jìn)行了重要的改進(jìn)。例如:?

1、Mybatis實(shí)現(xiàn)了接口綁定,使用更加方便。

在ibatis2.x中我們需要在DAO的實(shí)現(xiàn)類中指定具體對(duì)應(yīng)哪個(gè)xml映射文件,而Mybatis實(shí)現(xiàn)了DAO接口與xml映射文件的綁定,自動(dòng)為我們生成接口的具體實(shí)現(xiàn),使用起來(lái)變得更加省事和方便。?

2、對(duì)象關(guān)系映射的改進(jìn),效率更高?

3、MyBatis采用功能強(qiáng)大的基于OGNL的表達(dá)式來(lái)消除其他元素。 ?

對(duì)于IBatis與MyBatis的區(qū)別就不再多說(shuō)了,感興趣的朋友可以研究一下。

MyBatis的框架架構(gòu)

看到Mybatis的框架圖,可以清晰的看到Mybatis的整體核心對(duì)象,我更喜歡用自己的圖來(lái)表達(dá)Mybatis的整個(gè)的執(zhí)行流程。

原理詳解:

MyBatis應(yīng)用程序根據(jù)XML配置文件創(chuàng)建SqlSessionFactory,SqlSessionFactory在根據(jù)配置,配置來(lái)源于兩個(gè)地方,一處是配置文件,一處是Java代碼的注解,獲取一個(gè)SqlSession。SqlSession包含了執(zhí)行sql所需要的所有方法,可以通過(guò)SqlSession實(shí)例直接運(yùn)行映射的sql語(yǔ)句,完成對(duì)數(shù)據(jù)的增刪改查和事務(wù)提交等,用完之后關(guān)閉SqlSession。 ?

MyBatis的優(yōu)缺點(diǎn) ?

優(yōu)點(diǎn):

1、簡(jiǎn)單易學(xué)

mybatis本身就很小且簡(jiǎn)單。沒(méi)有任何第三方依賴,最簡(jiǎn)單安裝只要兩個(gè)jar文件+配置幾個(gè)sql映射文件易于學(xué)習(xí),易于使用,通過(guò)文檔和源代碼,可以比較完全的掌握它的設(shè)計(jì)思路和實(shí)現(xiàn)。 ?

2、靈活

mybatis不會(huì)對(duì)應(yīng)用程序或者數(shù)據(jù)庫(kù)的現(xiàn)有設(shè)計(jì)強(qiáng)加任何影響。sql寫在xml里,便于統(tǒng)一管理和優(yōu)化。通過(guò)sql基本上可以實(shí)現(xiàn)我們不使用數(shù)據(jù)訪問(wèn)框架可以實(shí)現(xiàn)的所有功能,或許更多。 ?

3、解除sql與程序代碼的耦合

通過(guò)提供DAL層,將業(yè)務(wù)邏輯和數(shù)據(jù)訪問(wèn)邏輯分離,使系統(tǒng)的設(shè)計(jì)更清晰,更易維護(hù),更易單元測(cè)試。sql和代碼的分離,提高了可維護(hù)性。?

4、提供映射標(biāo)簽,支持對(duì)象與數(shù)據(jù)庫(kù)的orm字段關(guān)系映射 ?

5、提供對(duì)象關(guān)系映射標(biāo)簽,支持對(duì)象關(guān)系組建維護(hù)?

6、提供xml標(biāo)簽,支持編寫動(dòng)態(tài)sql。?

缺點(diǎn):?

1、編寫SQL語(yǔ)句時(shí)工作量很大,尤其是字段多、關(guān)聯(lián)表多時(shí),更是如此。 ?

2、SQL語(yǔ)句依賴于數(shù)據(jù)庫(kù),導(dǎo)致數(shù)據(jù)庫(kù)移植性差,不能更換數(shù)據(jù)庫(kù)。

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

4、二級(jí)緩存機(jī)制不佳。

總結(jié)

mybatis的優(yōu)點(diǎn)同樣是mybatis的缺點(diǎn),正因?yàn)閙ybatis使用簡(jiǎn)單,數(shù)據(jù)的可靠性、完整性的瓶頸便更多依賴于程序員對(duì)sql的使用水平上了。sql寫在xml里,雖然方便了修改、優(yōu)化和統(tǒng)一瀏覽,但可讀性很低,調(diào)試也非常困難,也非常受限。mybatis沒(méi)有hibernate那么強(qiáng)大,但是mybatis最大的優(yōu)點(diǎn)就是簡(jiǎn)單小巧易于上手,方便瀏覽修改sql語(yǔ)句。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1. 簡(jiǎn)介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存儲(chǔ)過(guò)程以及高級(jí)映射的優(yōu)秀的...
    笨鳥慢飛閱讀 6,280評(píng)論 0 4
  • 1 引言# 本文主要講解JDBC怎么演變到Mybatis的漸變過(guò)程,重點(diǎn)講解了為什么要將JDBC封裝成Mybait...
    七寸知架構(gòu)閱讀 77,598評(píng)論 36 979
  • 11 MyBatis一級(jí)緩存實(shí)現(xiàn)# 11.1 什么是一級(jí)緩存? 為什么使用一級(jí)緩存?## 每當(dāng)我們使用MyBati...
    七寸知架構(gòu)閱讀 10,972評(píng)論 12 143
  • 原作者:anthony 譯者:勵(lì)定洲 當(dāng)用戶發(fā)現(xiàn)不能在你的網(wǎng)站上執(zhí)行某個(gè)行動(dòng)時(shí)就會(huì)感到受挫。舉個(gè)例子:當(dāng)你把按鍵都...
    定Ding閱讀 1,769評(píng)論 2 10
  • “小我” 我們有時(shí)候生氣,憤怒,做出了不該做的事情,有人說(shuō)是憤怒失去了理智,事后我們也說(shuō)那時(shí)候控制不住自己。其實(shí)這...
    一分凄涼閱讀 274評(píng)論 0 3

友情鏈接更多精彩內(nèi)容