1. 程式人生 > >Mybatis簡介與原理

Mybatis簡介與原理

背景介紹:

MyBatis 是支援普通 SQL查詢,儲存過程和高階對映的優秀持久層框架。MyBatis 消除了幾乎所有的JDBC程式碼和引數的手工設定以及結果集的檢索。MyBatis 使用簡單的 XML或註解用於配置和原始對映,將介面和 Java 的POJOs(Plain Old Java Objects,普通的 Java物件)對映成資料庫中的記錄。

原理詳解:

        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 一對多查詢(collection)  多對一查詢(association)