基本信息
MyBatis 是一款優秀的
持久層框架,它支持定製化
SQL、
存儲過程以及高級映射。MyBatis 避免了幾乎所有的 JDBC 代碼和手動設定參數以及獲取
結果集。MyBatis 可以使用簡單的 XML 或註解來配置和映射原生信息,將接口和 Java 的
POJOs(Plain Ordinary Java Object,普通的 Java對象)映射成資料庫中的記錄。
背景介紹
MyBatis 是支持普通 SQL查詢,
存儲過程和高級映射的優秀
持久層框架。MyBatis 消除了幾乎所有的
JDBC代碼和參數的手工設定以及
結果集的檢索。MyBatis 使用簡單的 XML或註解用於配置和原始映射,將接口和 Java 的
POJOs(Plain Ordinary Java Objects,普通的 Java對象)映射成資料庫中的記錄。
每個MyBatis
應用程式主要都是使用SqlSessionFactory實例的,一個Sql
SessionFactory實例可以通過SqlSessionFactoryBuilder獲得。SqlSessionFactoryBuilder可以從一個xml配置檔案或者一個預定義的配置類的實例獲得。
用
xml檔案構建SqlSessionFactory實例是非常簡單的事情。推薦在這個配置中使用類路徑資源(classpath resource),但你可以使用任何Reader實例,包括用檔案路徑或file://開頭的
url創建的實例。MyBatis有一個
實用類----Resources,它有很多方法,可以方便地從類路徑及其它位置載入資源。
特點
簡單易學:本身就很小且簡單。沒有任何第三方依賴,最簡單安裝只要兩個jar檔案+配置幾個sql映射檔案。易於學習,易於使用。通過文檔和原始碼,可以比較完全的掌握它的設計思路和實現。
靈活:mybatis不會對應用程式或者資料庫的現有設計強加任何影響。 sql寫在xml里,便於統一管理和最佳化。通過sql語句可以滿足運算元據庫的所有需求。
解除sql與程式代碼的耦合:通過提供DAO層,將業務邏輯和數據訪問邏輯分離,使系統的設計更清晰,更易維護,更易單元測試。sql和代碼的分離,提高了可維護性。
提供映射標籤,支持對象與資料庫的ORM欄位關係映射。
提供對象關係映射標籤,支持對象關係組建維護。
提供xml標籤,支持編寫動態sql。
總體流程
(1)載入配置並初始化
觸發條件:載入配置檔案
處理過程:將SQL的配置信息載入成為一個個MappedStatement對象(包括了傳入參數映射配置、執行的SQL語句、結果映射配置),存儲在記憶體中。
(2)接收調用請求
傳入參數:為SQL的ID和傳入參數對象
處理過程:將請求傳遞給下層的請求處理層進行處理。
(3)處理操作請求
觸發條件:API接口層傳遞請求過來
傳入參數:為SQL的ID和傳入參數對象
處理過程:
(A)根據SQL的ID查找對應的MappedStatement對象。
(B)根據傳入參數對象解析MappedStatement對象,得到最終要執行的SQL和執行傳入參數。
(C)獲取資料庫連線,根據得到的最終
SQL語句和執行傳入參數到資料庫執行,並得到執行結果。
(D)根據MappedStatement對象中的結果映射配置對得到的執行結果進行轉換處理,並得到最終的處理結果。
(E)釋放連線資源。
(4)返回處理結果將最終的處理結果返回。
功能架構
我們把Mybatis的功能架構分為三層:
(1)API接口層:提供給外部使用的接口API,開發人員通過這些本地API來操縱資料庫。接口層一接收到調用請求就會調用數據處理層來完成具體的數據處理。
(2)數據處理層:負責具體的SQL查找、SQL解析、SQL執行和執行結果映射處理等。它主要的目的是根據調用的請求完成一次
資料庫操作。
(3)基礎支撐層:負責最基礎的功能支撐,包括連線管理、
事務管理、配置載入和快取處理,這些都是共用的東西,將他們抽取出來作為最基礎的組件。為上層的數據處理層提供最基礎的支撐。
框架架構
框架架構講解:
(1)載入配置:配置來源於兩個地方,一處是
配置檔案,一處是Java代碼的註解,將SQL的配置信息載入成為一個個MappedStatement對象(包括了傳入參數映射配置、執行的SQL語句、結果映射配置),存儲在記憶體中。
(2)SQL解析:當API接口層接收到調用請求時,會接收到傳入SQL的ID和傳入對象(可以是Map、
JavaBean或者基本
數據類型),Mybatis會根據SQL的ID找到對應的MappedStatement,然後根據傳入參數對象對MappedStatement進行解析,解析後可以得到最終要執行的SQL語句和參數。
(3)SQL執行:將最終得到的SQL和參數拿到資料庫進行執行,得到運算元據庫的結果。
(4)結果映射:將運算元據庫的結果按照映射的配置進行轉換,可以轉換成HashMap、JavaBean或者基本數據類型,並將最終結果返回。
動態SQL
MyBatis 最強大的特性之一就是它的動態語句功能。如果您以前有使用JDBC或者類似框架的經歷,您就會明白把SQL語句條件連線在一起是多么的痛苦,要確保不能忘記空格或者不要在columns列後面省略一個逗號等。動態語句能夠完全解決掉這些痛苦。
儘管與動態SQL一起工作不是在開一個party,但是MyBatis確實能通過在任何映射SQL語句中使用強大的動態SQL來改進這些狀況。動態SQL元素對於任何使用過
JSTL或者類似於XML之類的
文本處理器的人來說,都是非常熟悉的。在上一版本中,需要了解和學習非常多的元素,但在MyBatis 3 中有了許多的改進,現在只剩下差不多二分之一的元素。MyBatis使用了基於強大的
OGNL表達式來消除了大部分元素。
集成
單獨使用mybatis是有很多限制的(比如無法實現跨越多個session的事務),而且很多
業務系統本來就是使用
spring來管理的事務,因此mybatis最好與spring集成起來使用。