最近研究了一下Mybatis,給大家磕叨磕叨砸烦,MyBatis框架的核心功能其實(shí)不難弃鸦,無非就是動(dòng)態(tài)代理和jdbc的操作,難的是寫出來可擴(kuò)展幢痘,高內(nèi)聚唬格,低耦合的規(guī)范的代碼。本文完成的Mybatis功能比較簡(jiǎn)單颜说,代碼還有許多需要改進(jìn)的地方购岗,大家可以結(jié)合Mybatis源碼去動(dòng)手完善。
一门粪、Mybatis框架流程簡(jiǎn)介
在手寫自己的Mybatis框架之前喊积,我們先來了解一下Mybatis,它的源碼中使用了大量的設(shè)計(jì)模式玄妈,閱讀源碼并觀察設(shè)計(jì)模式在其中的應(yīng)用乾吻,才能夠更深入的理解源碼(ref:Mybatis源碼解讀-設(shè)計(jì)模式總結(jié))髓梅。我們對(duì)上圖進(jìn)行分析總結(jié):
mybatis的配置文件有2類
mybatisconfig.xml,配置文件的名稱不是固定的绎签,配置了全局的參數(shù)的配置枯饿,全局只能有一個(gè)配置文件。
Mapper.xml 配置多個(gè)statemement诡必,也就是多個(gè)sql鸭你,整個(gè)mybatis框架中可以有多個(gè)Mappe.xml配置文件。
通過mybatis配置文件得到SqlSessionFactory
通過SqlSessionFactory得到SqlSession擒权,用SqlSession就可以操作數(shù)據(jù)了袱巨。
SqlSession通過底層的Executor(執(zhí)行器),執(zhí)行器有2類實(shí)現(xiàn):
基本實(shí)現(xiàn)
帶有緩存功能的實(shí)現(xiàn)
MappedStatement是通過Mapper.xml中定義statement生成的對(duì)象碳抄。
參數(shù)輸入執(zhí)行并輸出結(jié)果集愉老,無需手動(dòng)判斷參數(shù)類型和參數(shù)下標(biāo)位置,且自動(dòng)將結(jié)果集映射為Java對(duì)象
HashMap剖效,KV格式的數(shù)據(jù)類型
Java的基本數(shù)據(jù)類型
POJO嫉入,java的對(duì)象
二、梳理自己的Mybatis的設(shè)計(jì)思路
根據(jù)上文Mybatis流程璧尸,我簡(jiǎn)化了下咒林,分為以下步驟:
1.讀取xml文件,建立連接
從圖中可以看出爷光,MyConfiguration負(fù)責(zé)與人交互垫竞。待讀取xml后,將屬性和連接數(shù)據(jù)庫的操作封裝在MyConfiguration對(duì)象中供后面的組件調(diào)用蛀序。本文將使用dom4j來讀取xml文件欢瞪,它具有性能優(yōu)異和非常方便使用的特點(diǎn)。
2.創(chuàng)建SqlSession徐裸,搭建Configuration和Executor之間的橋梁
我們經(jīng)常在使用框架時(shí)看到Session遣鼓,Session到底是什么呢?一個(gè)Session僅擁有一個(gè)對(duì)應(yīng)的數(shù)據(jù)庫連接重贺。類似于一個(gè)前段請(qǐng)求Request骑祟,它可以直接調(diào)用exec(SQL)來執(zhí)行SQL語句。從流程圖中的箭頭可以看出气笙,MySqlSession的成員變量中必須得有MyExecutor和MyConfiguration去集中做調(diào)配次企,箭頭就像是一種關(guān)聯(lián)關(guān)系。我們自己的MySqlSession將有一個(gè)getMapper方法健民,然后使用動(dòng)態(tài)代理生成對(duì)象后抒巢,就可以做數(shù)據(jù)庫的操作了。
3.創(chuàng)建Executor秉犹,封裝JDBC操作數(shù)據(jù)庫
Executor是一個(gè)執(zhí)行器蛉谜,負(fù)責(zé)SQL語句的生成和查詢緩存(緩存還沒完成)的維護(hù),也就是jdbc的代碼將在這里完成崇堵,不過本文只實(shí)現(xiàn)了單表型诚,有興趣的同學(xué)可以嘗試完成多表。
4.創(chuàng)建MapperProxy鸳劳,使用動(dòng)態(tài)代理生成Mapper對(duì)象
我們只是希望對(duì)指定的接口生成一個(gè)對(duì)象狰贯,使得執(zhí)行它的時(shí)候能運(yùn)行一句sql罷了,而接口無法直接調(diào)用方法赏廓,所以這里使用動(dòng)態(tài)代理生成對(duì)象涵紊,在執(zhí)行時(shí)還是回到MySqlSession中調(diào)用查詢,最終由MyExecutor做JDBC查詢幔摸。這樣設(shè)計(jì)是為了單一職責(zé)摸柄,可擴(kuò)展性更強(qiáng)。
歡迎大家加入粉絲群:277763288既忆,群內(nèi)免費(fèi)分享Spring框架驱负、Mybatis框架SpringBoot框架、SpringMVC框架患雇、SpringCloud微服務(wù)跃脊、Dubbo框架、Redis緩存苛吱、RabbitMq消息酪术、JVM調(diào)優(yōu)、Tomcat容器翠储、MySQL數(shù)據(jù)庫教學(xué)視頻及架構(gòu)學(xué)習(xí)思維導(dǎo)圖
三拼缝、實(shí)現(xiàn)自己的Mybatis
工程文件及目錄:
首先,新建一個(gè)maven項(xiàng)目彰亥,在pom.xml中導(dǎo)入以下依賴:
創(chuàng)建我們的數(shù)據(jù)庫xml配置文件:
然后在數(shù)據(jù)庫創(chuàng)建test庫咧七,執(zhí)行如下SQL語句:
創(chuàng)建User實(shí)體類,和UserMapper接口和對(duì)應(yīng)的xml文件:
基本操作配置完成任斋,接下來我們開始實(shí)現(xiàn)MyConfiguration:
用面向?qū)ο蟮乃枷朐O(shè)計(jì)讀取xml配置后:
接下來實(shí)現(xiàn)我們的MySqlSession,首先的成員變量里得有Excutor和MyConfiguration继阻,代碼的精髓就在getMapper的方法里。
緊接著創(chuàng)建Excutor和實(shí)現(xiàn)類:
MyExcutor中封裝了JDBC的操作:
MyMapperProxy代理類完成xml方法和真實(shí)方法對(duì)應(yīng)废酷,執(zhí)行查詢:
到這里瘟檩,就完成了自己的Mybatis框架,我們測(cè)試一下:
歡迎大家加入粉絲群:277763288澈蟆,群內(nèi)免費(fèi)分享Spring框架墨辛、Mybatis框架SpringBoot框架、SpringMVC框架趴俘、SpringCloud微服務(wù)睹簇、Dubbo框架奏赘、Redis緩存、RabbitMq消息太惠、JVM調(diào)優(yōu)磨淌、Tomcat容器、MySQL數(shù)據(jù)庫教學(xué)視頻及架構(gòu)學(xué)習(xí)思維導(dǎo)圖
執(zhí)行結(jié)果:
查詢一個(gè)不存在的用戶試試:
到這里我們就大功告成了凿渊!
我自己在騰訊課堂上有錄制過一堂手寫mybatis的直播分享梁只,一堂課帶你深入了解mybatis
主要從以下來講述:
1.劃重點(diǎn)啦,花個(gè)三五分鐘回顧下MyBatis的要素埃脏;
2.想好了才能動(dòng)手搪锣,MyBatis核心流程解密;
3.一路向西彩掐,走三步手寫MyBatis,你一定能聽懂构舟!
4.老司機(jī)帶你大保健,居然我把MyBatis看懂了佩谷;
5.論學(xué)習(xí)源碼的重要性旁壮,是時(shí)候修煉內(nèi)功了!
6.互聯(lián)網(wǎng)架構(gòu)師技能樹梳理谐檀,作為一個(gè)互聯(lián)網(wǎng)高級(jí)架構(gòu)師你需要掌握的都在這里抡谐;
感興趣的可以進(jìn)群 277763288 獲取這堂課的直播鏈接學(xué)習(xí)學(xué)習(xí),群內(nèi)提供免費(fèi)的Java架構(gòu)學(xué)習(xí)資料(里面有高可用桐猬、高并發(fā)麦撵、高性能及分布式、Jvm性能調(diào)優(yōu)溃肪、Spring源碼免胃,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多個(gè)知識(shí)點(diǎn)的架構(gòu)資料)合理利用自己每一分每一秒的時(shí)間來學(xué)習(xí)提升自己惫撰,不要再用"沒有時(shí)間“來掩飾自己思想上的懶惰羔沙!趁年輕,使勁拼厨钻,給未來的自己一個(gè)交代扼雏!