什么是Mybatis
在保靖等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務理念,為客戶提供成都網(wǎng)站設(shè)計、做網(wǎng)站 網(wǎng)站設(shè)計制作按需開發(fā),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),成都品牌網(wǎng)站建設(shè),全網(wǎng)整合營銷推廣,外貿(mào)網(wǎng)站建設(shè),保靖網(wǎng)站建設(shè)費用合理。MyBatis 本是apache的一個開源項目iBatis, 2010年這個項目由apache software foundation 遷移到了google code,并且改名為MyBatis 。iBATIS一詞來源于“internet”和“abatis”的組合,是一個基于Java的持久層框架。iBATIS提供的持久層框架包括SQL Maps和Data Access Objects(DAO)。
MyBatis參考資料官網(wǎng):https://mybatis.github.io/mybatis-3/zh/index.html
官網(wǎng)對Mybatis的介紹更加具有權(quán)威性:
MyBatis 是支持定制化 SQL、存儲過程以及高級映射的優(yōu)秀的持久層框架。MyBatis 避免了幾乎所有的 JDBC 代碼和手工設(shè)置參數(shù)以及抽取結(jié)果集。MyBatis 使用簡單的 XML 或注解來配置和映射基本體,將接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java對象)映射成數(shù)據(jù)庫中的記錄。
MyBatis是iBatis的升級版,用法有很多的相似之處,但是MyBatis進行了重要的改進。例如:
1、Mybatis實現(xiàn)了接口綁定,使用更加方便。
在ibatis2.x中我們需要在DAO的實現(xiàn)類中指定具體對應哪個xml映射文件, 而Mybatis實現(xiàn)了DAO接口與xml映射文件的綁定,自動為我們生成接口的具體實現(xiàn),使用起來變得更加省事和方便。
2、對象關(guān)系映射的改進,效率更高
3、MyBatis采用功能強大的基于OGNL的表達式來消除其他元素。
對于IBatis與MyBatis的區(qū)別就不再多說了,感興趣的朋友可以研究一下。
MyBatis的框架架構(gòu)
看到Mybatis的框架圖,可以清晰的看到Mybatis的整體核心對象,我更喜歡用自己的圖來表達Mybatis的整個的執(zhí)行流程。如下圖所示:
原理詳解:
MyBatis應用程序根據(jù)XML配置文件創(chuàng)建SqlSessionFactory,SqlSessionFactory在根據(jù)配置,配置來源于兩個地方,一處是配置文件,一處是Java代碼的注解,獲取一個SqlSession。SqlSession包含了執(zhí)行sql所需要的所有方法,可以通過SqlSession實例直接運行映射的sql語句,完成對數(shù)據(jù)的增刪改查和事務提交等,用完之后關(guān)閉SqlSession。
MyBatis的優(yōu)缺點
優(yōu)點:
1、簡單易學
mybatis本身就很小且簡單。沒有任何第三方依賴,最簡單安裝只要兩個jar文件+配置幾個sql映射文件易于學習,易于使用,通過文檔和源代碼,可以比較完全的掌握它的設(shè)計思路和實現(xiàn)。
2、靈活
mybatis不會對應用程序或者數(shù)據(jù)庫的現(xiàn)有設(shè)計強加任何影響。 sql寫在xml里,便于統(tǒng)一管理和優(yōu)化。通過sql基本上可以實現(xiàn)我們不使用數(shù)據(jù)訪問框架可以實現(xiàn)的所有功能,或許更多。
3、解除sql與程序代碼的耦合
通過提供DAL層,將業(yè)務邏輯和數(shù)據(jù)訪問邏輯分離,使系統(tǒng)的設(shè)計更清晰,更易維護,更易單元測試。sql和代碼的分離,提高了可維護性。
4、提供映射標簽,支持對象與數(shù)據(jù)庫的orm字段關(guān)系映射
5、提供對象關(guān)系映射標簽,支持對象關(guān)系組建維護
6、提供xml標簽,支持編寫動態(tài)sql。
缺點:
1、編寫SQL語句時工作量很大,尤其是字段多、關(guān)聯(lián)表多時,更是如此。
2、SQL語句依賴于數(shù)據(jù)庫,導致數(shù)據(jù)庫移植性差,不能更換數(shù)據(jù)庫。
3、框架還是比較簡陋,功能尚有缺失,雖然簡化了數(shù)據(jù)綁定代碼,但是整個底層數(shù)據(jù)庫查詢實際還是要自己寫的,工作量也比較大,而且不太容易適應快速數(shù)據(jù)庫修改。
4、二級緩存機制不佳
總結(jié)
mybatis的優(yōu)點同樣是mybatis的缺點,正因為mybatis使用簡單,數(shù)據(jù)的可靠性、完整性的瓶頸便更多依賴于程序員對sql的使用水平上了。sql寫在xml里,雖然方便了修改、優(yōu)化和統(tǒng)一瀏覽,但可讀性很低,調(diào)試也非常困難,也非常受限。
mybatis沒有hibernate那么強大,但是mybatis大的優(yōu)點就是簡單小巧易于上手,方便瀏覽修改sql語句。
當前標題:Mybatis簡介與原理-創(chuàng)新互聯(lián)
URL鏈接:http://jinyejixie.com/article36/dhojsg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、企業(yè)網(wǎng)站制作、用戶體驗、建站公司、云服務器、微信小程序
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容