【持久化框架】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 本是apache的一個開源項目iBatis, 2010年這個項目由apache software foundation 遷移到了google code,並且改名爲MyBatis 。iBATIS一詞來源於“internet”和“abatis”的組合,是一個基於Java的持久層框架。iBATIS提供的持久層框架包括SQL Maps和Data Access Objects(DAO)。

[java] view plain copy print?

  1. MyBatis 是支持定製化 SQL、存儲過程以及高級映射的優秀的持久層框架。MyBatis 避免了幾乎所有的 JDBC 代碼和手工設置參數以及抽取結果集。MyBatis 使用簡單的 XML 或註解來配置和映射基本體,將接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java對象)映射成數據庫中的記錄。  


  2. MyBatis是iBatis的升級版,用法有很多的相似之處,但是MyBatis進行了重要的改進。例如:

  3.   

  4. 1、Mybatis實現了接口綁定,使用更加方便。

  5.  

  6.       在ibatis2.x中我們需要在DAO的實現類中指定具體對應哪個xml映射文件, 而Mybatis實現了DAO接口與xml映射文件的綁定,自動爲我們生成接口的具體實現,使用起來變得更加省事和方便。

  7.  

  8. 2、對象關係映射的改進,效率更高

  9.  

  10. 3、MyBatis採用功能強大的基於OGNL的表達式來消除其他元素。

  11.   

  12.        對於IBatis與MyBatis的區別就不再多說了,感興趣的朋友可以研究一下。

  13.  

  14. MyBatis的框架架構


  15.            

  16.         看到Mybatis的框架圖,可以清晰的看到Mybatis的整體核心對象,我更喜歡用自己的圖來表達Mybatis的整個的執行流程。如下圖所示:

  17.              

  18. 原理詳解:

  19.         MyBatis應用程序根據XML配置文件創建SqlSessionFactory,SqlSessionFactory在根據配置,配置來源於兩個地方,一處是配置文件,一處是Java代碼的註解,獲取一個SqlSession。SqlSession包含了執行sql所需要的所有方法,可以通過SqlSession實例直接運行映射的sql語句,完成對數據的增刪改查和事務提交等,用完之後關閉SqlSession。

  20.   

  21. MyBatis的優缺點

  22.   

  23. 優點:

  24. 1、簡單易學

  25.        mybatis本身就很小且簡單。沒有任何第三方依賴,最簡單安裝只要兩個jar文件+配置幾個sql映射文件易於學習,易於使用,通過文檔和源代碼,可以比較完全的掌握它的設計思路和實現。

  26.   

  27. 2、靈活

  28.        mybatis不會對應用程序或者數據庫的現有設計強加任何影響。 sql寫在xml裏,便於統一管理和優化。通過sql基本上可以實現我們不使用數據訪問框架可以實現的所有功能,或許更多。

  29.   

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

  31.        通過提供DAL層,將業務邏輯和數據訪問邏輯分離,使系統的設計更清晰,更易維護,更易單元測試。sql和代碼的分離,提高了可維護性。

  32.  

  33. 4、提供映射標籤,支持對象與數據庫的orm字段關係映射

  34.   
    5、提供對象關係映射標籤,支持對象關係組建維護

  35.  
    6、提供xml標籤,支持編寫動態sql。

  36.  

  37. 缺點:

  38.  

  39. 1、編寫SQL語句時工作量很大,尤其是字段多、關聯表多時,更是如此。

  40.   
    2、SQL語句依賴於數據庫,導致數據庫移植性差,不能更換數據庫。

  41.   

  42. 3、框架還是比較簡陋,功能尚有缺失,雖然簡化了數據綁定代碼,但是整個底層數據庫查詢實際還是要自己寫的,工作量也比較大,而且不太容易適應快速數據庫修改。

  43.   

  44. 4、二級緩存機制不佳

  45.  

  46. 總結

  47.  

  48.        mybatis的優點同樣是mybatis的缺點,正因爲mybatis使用簡單,數據的可靠性、完整性的瓶頸便更多依賴於程序員對sql的使用水平上了。sql寫在xml裏,雖然方便了修改、優化和統一瀏覽,但可讀性很低,調試也非常困難,也非常受限。

  49.      

    mybatis沒有hibernate那麼強大,但是mybatis最大的優點就是簡單小巧易於上手,方便瀏覽修改sql語句。

源碼來源:×××/technology

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章