mybatis的Configuration詳解
上一篇介紹了mybatis中SqlSessionFactory的創(chuàng)建過程,今天來(lái)學(xué)習(xí)它默認(rèn)實(shí)現(xiàn)中的唯一屬性Configuration
回顧
還是最開始的mybatis源碼環(huán)境中的測(cè)試代碼如下圖:
利用mybatis查出數(shù)據(jù)只用三步:創(chuàng)建SqlSessionFactory、通過SqlSessionFactory創(chuàng)建SqlSession、SqlSession執(zhí)行selectOne方法。
上一篇文章梳理了SqlSessionFactory創(chuàng)建過程的源碼,發(fā)現(xiàn)它返回的是它的默認(rèn)實(shí)現(xiàn)類DefaultSqlSessionFactory,而默認(rèn)實(shí)現(xiàn)類有有唯一的一個(gè)屬性configuration,所以SqlSessionFactory根本的依賴還是Configuration類。
Configuration基礎(chǔ)信息說(shuō)明
Configuration類中有很多的屬性,下面是基礎(chǔ)屬性的源碼以及部分說(shuō)明如下圖:
上面主要是一些settings屬性,settings屬性是MyBatis 的基礎(chǔ)性設(shè)置,它們會(huì)改變 MyBatis 的運(yùn)行時(shí)行為。更加完整的說(shuō)明在官方文檔上:https://mybatis.org/mybatis-3/zh/configuration.html。去掉zh可以查看英文版本。
這里面有一個(gè)熟悉protected Properties variables = new Properties();這個(gè)屬性對(duì)應(yīng)是我們?cè)趍ybatis配置文件中有時(shí)會(huì)配置的properties節(jié)點(diǎn)的內(nèi)容,有時(shí)候我們會(huì)配置url、driver、username、password等信息。然后在其他節(jié)點(diǎn)使用${}來(lái)使用。
擴(kuò)展屬性和無(wú)參構(gòu)造
上面介紹了決定mybatis一些基礎(chǔ)行為的屬性,在Configuration還存有一些mybatis可用來(lái)擴(kuò)展的和運(yùn)行中需要信息,下圖中是這些屬性已經(jīng)Configuration的無(wú)參構(gòu)造函數(shù):
上一節(jié)是mybatis中的環(huán)境配置信息,而上圖是一些mybatis運(yùn)行中要用到的信息,比如:resultMap集合、sql語(yǔ)句集合、插件列表、緩存、類型別名、類型處理器等。
其中很多屬性使用的是Configuration中的了一個(gè)內(nèi)部靜態(tài)類StrictMap,它繼承自HashMap,對(duì)HashMap的裝飾在于增加了put時(shí)防重復(fù)的處理,get時(shí)取不到值時(shí)候的異常處理,這樣在使用時(shí)就不需要關(guān)心各種異常,簡(jiǎn)化應(yīng)用層邏輯。
Configuration的無(wú)參構(gòu)造函數(shù)主要往typeAliasRegistry中put了一些數(shù)據(jù),typeAliasRegistry是類型注冊(cè)器,通過這段代碼知道為什么可以在配置文件中配置“”這類信息了,因?yàn)橥ㄟ^type的值能夠找到對(duì)應(yīng)的類。
再看parse方法
在上一篇文章SqlSessionFactory創(chuàng)建過程中講到了Configuration是通過無(wú)參構(gòu)造函數(shù)創(chuàng)建了一個(gè)Configuration對(duì)象,然后在最后調(diào)用了parse方法。無(wú)參構(gòu)造函數(shù)上一節(jié)已經(jīng)進(jìn)行了說(shuō)明,最后再來(lái)看上一篇文章最后的parse方法調(diào)用的parseConfiguration方法如下圖:
這次在看parseConfiguration方法中的內(nèi)容就更加清楚在干嘛了。
總結(jié)
今天只梳理了Configuration中包含的屬性以及默認(rèn)構(gòu)造函數(shù),分析完成后最終還是指向了上一篇文章的parseConfiguration方法,那么從下一篇文章開始就來(lái)仔細(xì)分析一下parseConfiguration對(duì)Configuration具體做了哪些設(shè)置以及流程。
到此這篇關(guān)于mybatis的Configuration詳解的文章就介紹到這了,更多相關(guān)mybatis Configuration內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. DB2的高可用性和災(zāi)難恢復(fù)概述2. 有時(shí)Oracle不用索引來(lái)查找數(shù)據(jù)的原因3. 使用DB2look重新創(chuàng)建優(yōu)化器訪問計(jì)劃(4)4. 使用DB2 9 pureXML管理ODF和Microsoft Office 2007 文檔(1)5. MySQL如何從不固定位置提取字符串元素詳解6. Microsoft Office Access添加外鍵的方法7. 記一次mariadb數(shù)據(jù)庫(kù)無(wú)法連接8. sqlserver給表添加新字段、給表和字段添加備注、更新備注及查詢備注(sql語(yǔ)句)9. Microsoft Office Access添加圖片的方法10. Mac上安裝Mysql的詳細(xì)步驟及配置
