1. 程式人生 > >【持久化框架】Mybatis簡介與原理

【持久化框架】Mybatis簡介與原理

什麼是Mybatis          MyBatis 本是apache的一個開源專案iBatis, 2010年這個專案由apache software foundation 遷移到了google code,並且改名為MyBatis 。iBATIS一詞來源於“internet”和“abatis”的組合,是一個基於Java的持久層框架。iBATIS提供的持久層框架包括SQL Maps和Data Access Objects(DAO)。       MyBatis參考資料官網:https://mybatis.github.io/mybatis-3/zh/index.html 官網對Mybatis的介紹更加具有權威性:  

   MyBatis 是支援定製化 SQL、儲存過程以及高階對映的優秀的持久層框架。MyBatis 避免了幾乎所有的 JDBC 程式碼和手工設定引數以及抽取結果集。MyBatis 使用簡單的 XML 或註解來配置和對映基本體,將介面和 Java 的 POJOs(Plain Old Java Objects,普通的 Java物件)對映成資料庫中的記錄。

       MyBatis是iBatis的升級版,用法有很多的相似之處,但是MyBatis進行了重要的改進。例如:   1、Mybatis實現了介面繫結,使用更加方便。         在ibatis2.x中我們需要在DAO的實現類中指定具體對應哪個xml對映檔案, 而Mybatis實現了DAO介面與xml對映檔案的繫結,自動為我們生成介面的具體實現,使用起來變得更加省事和方便。   2、物件關係對映的改進,效率更高   3、MyBatis採用功能強大的基於OGNL的表示式來消除其他元素。          對於IBatis與MyBatis的區別就不再多說了,感興趣的朋友可以研究一下。   MyBatis的框架架構

                    看到Mybatis的框架圖,可以清晰的看到Mybatis的整體核心物件,我更喜歡用自己的圖來表達Mybatis的整個的執行流程。如下圖所示:               原理詳解:         MyBatis應用程式根據XML配置檔案建立SqlSessionFactory,SqlSessionFactory在根據配置,配置來源於兩個地方,一處是配置檔案,一處是Java程式碼的註解,獲取一個SqlSession。SqlSession包含了執行sql所需要的所有方法,可以通過SqlSession例項直接執行對映的sql語句,完成對資料的增刪改查和事務提交等,用完之後關閉SqlSession。   MyBatis的優缺點   優點: 1、簡單易學        mybatis本身就很小且簡單。沒有任何第三方依賴,最簡單安裝只要兩個jar檔案+配置幾個sql對映檔案易於學習,易於使用,通過文件和原始碼,可以比較完全的掌握它的設計思路和實現。   2、靈活        mybatis不會對應用程式或者資料庫的現有設計強加任何影響。 sql寫在xml裡,便於統一管理和優化。通過sql基本上可以實現我們不使用資料訪問框架可以實現的所有功能,或許更多。   3、解除sql與程式程式碼的耦合        通過提供DAL層,將業務邏輯和資料訪問邏輯分離,使系統的設計更清晰,更易維護,更易單元測試。sql和程式碼的分離,提高了可維護性。   4、提供對映標籤,支援物件與資料庫的orm欄位關係對映   5、提供物件關係對映標籤,支援物件關係組建維護  6、提供xml標籤,支援編寫動態sql。   缺點:   1、編寫SQL語句時工作量很大,尤其是欄位多、關聯表多時,更是如此。   2、SQL語句依賴於資料庫,導致資料庫移植性差,不能更換資料庫。   3、框架還是比較簡陋,功能尚有缺失,雖然簡化了資料繫結程式碼,但是整個底層資料庫查詢實際還是要自己寫的,工作量也比較大,而且不太容易適應快速資料庫修改。   4、二級快取機制不佳   總結          mybatis的優點同樣是mybatis的缺點,正因為mybatis使用簡單,資料的可靠性、完整性的瓶頸便更多依賴於程式設計師對sql的使用水平上了。sql寫在xml裡,雖然方便了修改、優化和統一瀏覽,但可讀性很低,除錯也非常困難,也非常受限。       mybatis沒有hibernate那麼強大,但是mybatis最大的優點就是簡單小巧易於上手,方便瀏覽修改sql語句。