Mybatis SQL運(yùn)行流程源碼詳解
概述
源碼就是能夠被用來執(zhí)行,生成機(jī)器能夠識(shí)別的代碼,通過開源源碼,可以引用其功能。
重要性
1、mybatis中的sql執(zhí)行,不僅要知道返回的結(jié)果是什么,還需要知道這結(jié)果是怎么來的,經(jīng)過了怎樣的處理,只有知道了這樣的原理,碰到問題才能更好的知道問題出在那個(gè)環(huán)節(jié)。
2、能更好的擴(kuò)展應(yīng)用程序,可以做到代碼的復(fù)用,減少開發(fā)成本和時(shí)間。
3、學(xué)習(xí)其中的設(shè)計(jì)思想能夠在其他應(yīng)用得已應(yīng)用。
步驟
源碼閱讀,可以從測(cè)試用例著手,每個(gè)源碼,多有大師們寫的測(cè)試用例,咱們可以用大師們寫的測(cè)試用例進(jìn)行相關(guān)功能的測(cè)試,這樣就可以知道其中的運(yùn)行原理及一些設(shè)計(jì)思想。
步驟1 測(cè)試用例請(qǐng)求

步驟2 進(jìn)行MapperProxy對(duì)象,MapperProxy代理是jdk動(dòng)態(tài)代理,根據(jù)傳入的mapper接口,動(dòng)態(tài)生成代理對(duì)象,代理對(duì)象同時(shí)實(shí)現(xiàn)了InvocationHandler接口。



步驟3:進(jìn)行到MapperMethod類,通過構(gòu)造器初始化SqlCommand靜態(tài)內(nèi)部類,跟配置文件的方法簽名對(duì)比,是不是有對(duì)應(yīng)的方法。

步驟4 進(jìn)行execute選擇執(zhí)行的Sqlsession


步驟5 進(jìn)入DefaultSqlsession,選擇執(zhí)行的執(zhí)行器,先選擇緩存執(zhí)行器,緩存沒有選擇默認(rèn)的簡(jiǎn)單執(zhí)行器,如果mybatis有配置,就選擇配置的執(zhí)行器,并設(shè)置預(yù)處理參數(shù)。


步驟6 進(jìn)入申明處理對(duì)象進(jìn)行查詢,返回結(jié)果集

流程的請(qǐng)求總結(jié)

總結(jié)
1、mybatis使用了jdk的動(dòng)態(tài)代理,在程序執(zhí)行的時(shí)候生成一個(gè)具體的代理對(duì)象,執(zhí)行相關(guān)的邏輯,可以在代理的方法前后執(zhí)行一些邏輯,不用改變?cè)瓉眍惖倪壿嫞湍茉鰪?qiáng)類方法的功能,在編寫底層代碼的時(shí)候動(dòng)態(tài)代理尤其重要;
2、應(yīng)用廣泛比如事物的管理、spring aop的原理實(shí)現(xiàn),登錄權(quán)限攔截、日志的統(tǒng)一輸出、統(tǒng)計(jì)每個(gè) api 的請(qǐng)求耗時(shí)等等。
3、研究源碼并不是為了研究而研究,要學(xué)習(xí)其中的思想,比如動(dòng)態(tài)代理、工廠模式、建造者模式,要利用這些原則來增加程序的可維護(hù)性、復(fù)用性、靈活性、可靠性。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 如何安裝MySQL 壓縮包2. 相同平臺(tái)下DB2數(shù)據(jù)庫(kù)使用重定向恢復(fù)示例3. Sql Server 壓縮數(shù)據(jù)庫(kù)日志文件的方法4. MySQL創(chuàng)始人發(fā)郵件尋求中國(guó)幫助5. MySQL存儲(chǔ)引擎選擇InnoDB還是MyISAM6. Oracle數(shù)據(jù)庫(kù)的兩種授權(quán)收費(fèi)方式詳解7. 數(shù)據(jù)庫(kù)Oracle9i的企業(yè)管理器簡(jiǎn)介8. 巧用SQL語言在ACCESS數(shù)據(jù)庫(kù)中批量替換內(nèi)容9. 簡(jiǎn)化 DB2 for i5/OS 索引建議10. 學(xué)好Oracle的六條總結(jié)

網(wǎng)公網(wǎng)安備