精心挑選要閱讀的源碼項目;git
飲水思源——官方文檔,先看文檔再看源碼;github
下載源碼,安裝到本地,保證能編譯運行;sql
從宏觀到微觀,從總體到細節;數據庫
找到入口,抓主放次,梳理核心流程;session
源碼調試,找到核心數據結構和關鍵類;數據結構
勤練習,多折騰;mybatis
進入光標選中的propertiesElement方法內發現,mybatis初始化的時候會把配置文件內的信息放入configuration對象對應的屬性內:架構
根據sql的類型update,insert,select,delete 縮小查找範圍,而後根據sql的返回類型map?list?就可惟一肯定一個sqlsession執行方法app
mybatis mapper接口並無實現類,運行中如何判調用的具體方法,執行指定的sql語句???框架
遵循jdbc的規範,先上一段jdbc代碼拋磚引玉:
StatementHandler:它的做用是使用數據庫的Statement或PrepareStatement執行操做,啓承上啓下做用;
ParameterHandler:對預編譯的SQL語句進行參數設置
ResultSetHandler:對數據庫返回的結果集(ResultSet)進行封裝,返回用戶指定的實體類型;
接着上一段源碼,進入selelectList()方法。
ParameterHandler 組件已經飢渴難耐了。
MyBatis 是一款優秀的持久層框架,它支持定製化 SQL、存儲過程以及高級映射。MyBatis 避免了幾乎全部的 JDBC 代碼和手動設置參數以及獲取結果集。
MyBatis 能夠使用簡單的 XML 或註解來配置和映射原生信息,將接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java對象)映射成數據庫中的記錄。