Mybatis框架介紹

什麼是MyBatis

myBatis的前身是iBatis框架由google code 研發,是一個基於Java的持久層框架。 myBatis是支持定製化  SQL .存儲過程以及高級優秀的持久性框架,    mybatis避免了幾乎所有的 jdbc 代碼和手工設置參數以及抽取結果集。mybatis 使用簡單的XML 或註解來配置和映射基本體,將接口和 JavaPOJOs

(普通Java類)映射成數據庫中的記錄。


 MyBatis 在 iBatis 之後進行了重要的改進。例如:

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

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

3.對象關係映射的改進,效率更高。

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


MyBatis框架架構

MyBatis




原理講解:

MyBatis應用程序根據 XML 配置文件創建 SqlSessionFactory. SqlSessionFactory 再根據配置,獲取一個 SqlSession. 配置來源兩個地方,一個是文件配置,一個是Java代碼註解。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框架configuration.xml配置



Mapper.xml配置:

1.添加數據獲取ID




2.查詢數據可通過傳入不同值進行查詢




模糊查詢




多表聯查




其他刪除修改和sql 語句一樣

myBatis簡單封裝