Mybatis SQL運(yùn)行流程源碼詳解
概述
源碼就是能夠被用來(lái)執(zhí)行,生成機(jī)器能夠識(shí)別的代碼,通過(guò)開源源碼,可以引用其功能。
重要性
1、mybatis中的sql執(zhí)行,不僅要知道返回的結(jié)果是什么,還需要知道這結(jié)果是怎么來(lái)的,經(jīng)過(guò)了怎樣的處理,只有知道了這樣的原理,碰到問(wèn)題才能更好的知道問(wèn)題出在那個(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類,通過(guò)構(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è)瓉?lái)類的邏輯,就能增強(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)代理、工廠模式、建造者模式,要利用這些原則來(lái)增加程序的可維護(hù)性、復(fù)用性、靈活性、可靠性。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. Sqlserver之死鎖查詢以及批量解鎖的實(shí)現(xiàn)方法2. 簡(jiǎn)單了解mysql語(yǔ)句書寫和執(zhí)行順序3. Access數(shù)據(jù)庫(kù)安全的幾個(gè)問(wèn)題4. MyBatis-Plus多表聯(lián)合查詢并且分頁(yè)(3表聯(lián)合)5. Oracle中PL/SQL單行函數(shù)和組函數(shù)詳解6. MySQL 8.0新特性 — 管理端口的使用簡(jiǎn)介7. 一文詳解嵌入式SQL8. 如何將Mybatis連接到ClickHouse9. 全面解析Oracle developer的異常處理機(jī)制10. Mysql索引常見問(wèn)題匯總
