Mybatis SQL運(yùn)行流程源碼詳解
概述
源碼就是能夠被用來(lái)執(zhí)行,生成機(jī)器能夠識(shí)別的代碼,通過(guò)開(kāi)源源碼,可以引用其功能。
重要性
1、mybatis中的sql執(zhí)行,不僅要知道返回的結(jié)果是什么,還需要知道這結(jié)果是怎么來(lái)的,經(jīng)過(guò)了怎樣的處理,只有知道了這樣的原理,碰到問(wèn)題才能更好的知道問(wèn)題出在那個(gè)環(huán)節(jié)。
2、能更好的擴(kuò)展應(yīng)用程序,可以做到代碼的復(fù)用,減少開(kāi)發(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í)行器,緩存沒(méi)有選擇默認(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í)有所幫助,也希望大家多多支持腳本之家。
- 使用MyBatisPlus自動(dòng)生成代碼后tomcat運(yùn)行報(bào)錯(cuò)的問(wèn)題及解決方法
- Mybatis逆向工程運(yùn)行代碼實(shí)例
- Mybatis工具類JdbcTypeInterceptor運(yùn)行時(shí)自動(dòng)添加jdbcType屬性
- Mybatis源碼分析之存儲(chǔ)過(guò)程調(diào)用和運(yùn)行流程
- 詳解MyBatis工作原理
- MyBatis緩存實(shí)現(xiàn)原理及代碼實(shí)例解析
- Mybatis Mapper接口工作原理實(shí)例解析
- 簡(jiǎn)單了解mybatis攔截器實(shí)現(xiàn)原理及實(shí)例
- 分析mybatis運(yùn)行原理
相關(guān)文章
Java?數(shù)據(jù)結(jié)構(gòu)深入理解ArrayList與順序表
ArrayList?類是一個(gè)可以動(dòng)態(tài)修改的數(shù)組,與普通數(shù)組的區(qū)別就是它是沒(méi)有固定大小的限制,我們可以添加或刪除元素。ArrayList?繼承了?AbstractList?,并實(shí)現(xiàn)了?List?接口,順序表是將元素順序地存放在一塊連續(xù)的存儲(chǔ)區(qū)里,元素間的順序關(guān)系由它們的存儲(chǔ)順序自然表示2022-04-04Java數(shù)據(jù)結(jié)構(gòu)之鏈表的增刪查改詳解
今天帶大家來(lái)學(xué)習(xí)Java鏈表的增刪改查的相關(guān)知識(shí),文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)Java的小伙伴們有很好的幫助,需要的朋友可以參考下2021-05-05Java使用jdbc連接實(shí)現(xiàn)對(duì)MySQL增刪改查操作的全過(guò)程
JDBC的全稱是Java?Database?Connectivity,即Java數(shù)據(jù)庫(kù)連接,它是一種可以執(zhí)行SQL語(yǔ)句的Java?API,下面這篇文章主要給大家介紹了關(guān)于Java使用jdbc連接實(shí)現(xiàn)對(duì)MySQL增刪改查操作的相關(guān)資料,需要的朋友可以參考下2023-03-03詳解Spring依賴注入:@Autowired,@Resource和@Inject區(qū)別與實(shí)現(xiàn)原理
這篇文章主要介紹了詳解Spring依賴注入:@Autowired,@Resource和@Inject區(qū)別與實(shí)現(xiàn)原理,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-06-06mybatis中關(guān)于type-aliases-package的使用
這篇文章主要介紹了mybatis中關(guān)于type-aliases-package的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08