阿里P8淺析從 0 開始手寫一個(gè) Mybatis 框架飞傀,三步搞定皇型!

最近研究了一下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è)交代扼雏!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市夯膀,隨后出現(xiàn)的幾起案子诗充,更是在濱河造成了極大的恐慌,老刑警劉巖诱建,帶你破解...
    沈念sama閱讀 212,686評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蝴蜓,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)茎匠,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,668評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門格仲,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人汽抚,你說我怎么就攤上這事抓狭〔。” “怎么了造烁?”我有些...
    開封第一講書人閱讀 158,160評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)午笛。 經(jīng)常有香客問我惭蟋,道長(zhǎng),這世上最難降的妖魔是什么药磺? 我笑而不...
    開封第一講書人閱讀 56,736評(píng)論 1 284
  • 正文 為了忘掉前任告组,我火速辦了婚禮,結(jié)果婚禮上癌佩,老公的妹妹穿的比我還像新娘木缝。我一直安慰自己,他們只是感情好围辙,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,847評(píng)論 6 386
  • 文/花漫 我一把揭開白布我碟。 她就那樣靜靜地躺著,像睡著了一般姚建。 火紅的嫁衣襯著肌膚如雪矫俺。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,043評(píng)論 1 291
  • 那天掸冤,我揣著相機(jī)與錄音厘托,去河邊找鬼。 笑死稿湿,一個(gè)胖子當(dāng)著我的面吹牛铅匹,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播饺藤,決...
    沈念sama閱讀 39,129評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼包斑,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了策精?” 一聲冷哼從身側(cè)響起舰始,我...
    開封第一講書人閱讀 37,872評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎咽袜,沒想到半個(gè)月后丸卷,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,318評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡询刹,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,645評(píng)論 2 327
  • 正文 我和宋清朗相戀三年谜嫉,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了萎坷。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,777評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡沐兰,死狀恐怖哆档,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情住闯,我是刑警寧澤瓜浸,帶...
    沈念sama閱讀 34,470評(píng)論 4 333
  • 正文 年R本政府宣布,位于F島的核電站比原,受9級(jí)特大地震影響插佛,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜量窘,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,126評(píng)論 3 317
  • 文/蒙蒙 一雇寇、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蚌铜,春花似錦锨侯、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,861評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至造壮,卻和暖如春渡讼,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背耳璧。 一陣腳步聲響...
    開封第一講書人閱讀 32,095評(píng)論 1 267
  • 我被黑心中介騙來泰國打工成箫, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人旨枯。 一個(gè)月前我還...
    沈念sama閱讀 46,589評(píng)論 2 362
  • 正文 我出身青樓蹬昌,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親攀隔。 傳聞我的和親對(duì)象是個(gè)殘疾皇子皂贩,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,687評(píng)論 2 351

推薦閱讀更多精彩內(nèi)容