国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

解決SpringBoot整合MybatisPlus分模塊管理遇到的bug

瀏覽:5日期:2023-02-21 17:53:32
前言

這個Bug前前后后折騰了兩天才找到答案,雖說不是完全兩天的工作時間在調(diào)試這個問題,但是過程也確實曲折,所以做一下記錄,也當(dāng)做一次自我反省

背景

SpringBoot 與 MyBatis-Plus 的 pom 依賴

<!-- SpringBoot 版本 --><parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.9.RELEASE</version> <relativePath/> <!-- lookup parent from repository --></parent><!-- MyBatis-plus 版本 --><dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.1.0</version></dependency>

項目分模塊結(jié)構(gòu)

解決SpringBoot整合MybatisPlus分模塊管理遇到的bug

之前一直停留在 SpringBoot 整合其他框架做一些小項目,所以都是把代碼放在一個工程,也沒有進(jìn)行分模塊管理。

由于公司打算開發(fā)新產(chǎn)品,我想嘗試在 SpringBoot 的項目來做分模塊的開發(fā)(Maven工程),并且用 MyBatis-Plus 來做持久層框架,也就是將 SpringBoot 做 web模塊, 實體跟Mapper 拆分到 persistence模塊,并將 mapper.xml 文件放在 persistence模塊 的 resources/mapper 目錄下。

在項目分模塊完成之后,并進(jìn)行代碼移植時并沒有發(fā)現(xiàn)問題,因為此時并不需要調(diào)用到自定義 mapper.xml 中的 sql 查詢數(shù)據(jù)庫。但隨著一步一步的完善代碼,也開始需要用到 mapper.xml 的 sql 查詢,此時,在調(diào)試時,發(fā)現(xiàn)了如下錯誤:

解決SpringBoot整合MybatisPlus分模塊管理遇到的bug

即,報找不到對應(yīng)的 sql

排查原因排除 mapper.xml 書寫錯誤

首先排除 mapper.xml 中 namespace 或 sql 的 id 寫錯,因為我的開發(fā)工具下載了 MybatisX 的插件,mapper.java 與 mapper.xml 都有插件的小圖標(biāo),如下圖所示,

解決SpringBoot整合MybatisPlus分模塊管理遇到的bug 解決SpringBoot整合MybatisPlus分模塊管理遇到的bug

懷疑:分模塊導(dǎo)致

其次,在先前我已經(jīng)整合過 SpringBoot 與 MyBatis-Plus 單項目的工程,并沒有這個問題,所以,我懷疑是因為 分模塊導(dǎo)致的原因 導(dǎo)致的,所以,我想 分模塊跟不分模塊的工程 有區(qū)別?

區(qū)別就是,不分模塊 mapper.xml 文件就在項目 classes 下的 mapper 中,而分模塊后, mapper.xml 文件就在 persistence模塊打出來的 jar 中

錯誤思路:修改pom文件配置resources目錄

所以,發(fā)現(xiàn)了這點之后,就開始必應(yīng)解決方案,但是剛開始我的思路是 錯誤的,我以為項目打包之后,沒有把 persistence模塊的 resources 下 的 mapper 目錄打包進(jìn) jar 中 。浪費(fèi)了一些時間之后,我才想清楚應(yīng)該先去 persistence模塊 打出來的 jar 中確認(rèn)有沒有將 resources 下的 mapper/mapper.xml 打包進(jìn)去。

解決SpringBoot整合MybatisPlus分模塊管理遇到的bug

懷疑:Spring Resource時沒有加載 jar 中的 mapper.xml

上面的問題教了自己一課,眼見為實 ,雖然解決 Bug 的過程中,合理的猜測是必要的,但是在有限的結(jié)果集中,驗證排除一些錯誤的思路更為重要。就像,經(jīng)常有人會問我,“為什么我運(yùn)行老是報找不到類的錯誤”,我就說那你到 tomcat 的發(fā)布路徑上看一下 jar 包有沒有發(fā)不上去,這其實是一個道理的。

回到問題,為什么Spring Resource時沒有加載 jar 中的 mapper.xml ?必應(yīng)尋找解決方案,在必應(yīng)的過程中我才想起了 Spring 的 Resource 加載文件, classpath 與 classpath* 的區(qū)別,好久沒有自己手寫搭項目,把這個給忘記了。

解決SpringBoot整合MybatisPlus分模塊管理遇到的bug

所以,此時我確信將 application.xml 中 mybatis-plus.mapper-locations 的值改為 classpath*:mapper/*Mapper.xml 即可,如下

#mapper plusmybatis-plus: mapper-locations: classpath*:mapper/*Mapper.xml懷疑:SpringBoot 跟 MyBatis-Plus 整合的配置哪里不對嗎?

上面的配置修改之后,重新運(yùn)行,還是報同樣的錯?。。?/p>

解決SpringBoot整合MybatisPlus分模塊管理遇到的bug

What The Fuck?。?!因為我覺得這個 bug 就是由于 classpath:mapper/*Mapper.xml Spring 的 Resource 只能掃描當(dāng)前應(yīng)用中的 classpath 下的 mapper 目錄的 mapper.xml 的文件,所以,我又重新必應(yīng)了 SpringBoot 與 Mybati-plus 的整合配置 ,說到底還是對這個框架不了解,導(dǎo)致走了不少彎路,而且在出問題的時候,沒有堅信自己的判斷,而不斷的嘗試必應(yīng)出來的結(jié)果,使得又浪費(fèi)了一些時間在這個問題上。

最后必應(yīng)了一圈后,還是沒有找到解決方案,而且與此相關(guān)的問題文章也不多, 我開始迷茫跟急躁了,畢竟已經(jīng)浪費(fèi)了這么多的時間,我還是決定先驗證一下我前面深信的東西---- Spring 的 Resource 加載文件, classpath 與 classpath* 的區(qū)別 ,所以,我決定自己創(chuàng)建 sqlSessionFactory ,代碼如下

@Bean('sqlSessionFactory')public SqlSessionFactory sqlSessionFactory() throws Exception { MybatisSqlSessionFactoryBean sqlSessionFactory = new MybatisSqlSessionFactoryBean(); sqlSessionFactory.setDataSource(datasource); ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver(); Resource[] resources = resolver.getResources('classpath*:mapper/*Mapper.xml'); sqlSessionFactory.setMapperLocations(resources); MybatisConfiguration configuration = new MybatisConfiguration(); configuration.setJdbcTypeForNull(JdbcType.NULL); configuration.setMapUnderscoreToCamelCase(true); configuration.setCacheEnabled(false); sqlSessionFactory.setConfiguration(configuration); //添加分頁功能 sqlSessionFactory.setPlugins(new Interceptor[]{paginationInterceptor() }); return sqlSessionFactory.getObject();}

結(jié)果是運(yùn)行通過了?。〔贿^,這也是理所當(dāng)然的,這就說明了我在 application.xml 中 mybatis-plus 的配置沒生效,相當(dāng)于又回到了上一個問題。到了這里,我才想到去看 mybatis-plus-boot-starter 里面的源碼??!

沒想到的是,源碼相當(dāng)容易看,首先,jar 包的目錄結(jié)構(gòu)如下,看名字直接選擇看 MybatisPlusAutoConfiguration 這個配置類

解決SpringBoot整合MybatisPlus分模塊管理遇到的bug

打開 MybatisPlusAutoConfiguration 的源碼,直接看 SqlSessionFactory 的創(chuàng)建,如下,在設(shè)置 mapper-locations 的判斷處,打下斷點,進(jìn)行調(diào)試

解決SpringBoot整合MybatisPlus分模塊管理遇到的bug

并且將前面自定義創(chuàng)建的 SqlSessionFactory 的代碼注釋掉,application.yml 中配置 mapper-locations: classpath*:mapper/*Mapper.xml ,重新運(yùn)行,進(jìn)行源碼調(diào)試,發(fā)現(xiàn)上圖斷點的邏輯,沒有進(jìn)到 if 的判斷中去,調(diào)試的 MybatisPlusProperties 對象結(jié)果如下,

解決SpringBoot整合MybatisPlus分模塊管理遇到的bug

?。?!What The Fuck!!!我配置的明明是 classpath*:mapper/*Mapper.xml ,怎么變成了 classpath:mapper/*Mapper.xml 可恨的是,我的思路有繞彎了!??!

懷疑:yml 的配置語法對 classpath*:mapper/*Mapper.xml 解析有問題

我都服了我自己了,但確實是這次修改讓我找到了最后的答案,將原本的配置寫法改成了數(shù)組,寫法如下,

#mapper plusmybatis-plus: mapper-locations: [classpath*:mapper/*Mapper.xml]

因為對這種配置格式也沒去深究,之前都是一對一的配置項,沒有嘗試過數(shù)組的寫法,所以上來就運(yùn)行報錯了,但是報的是 application.yml 的語法格式有誤。所以,將值加上引號括起來,變成

#mapper plusmybatis-plus: mapper-locations: ['classpath*:mapper/*Mapper.xml']

重新運(yùn)行,發(fā)現(xiàn)竟然通過了?。。≡创a調(diào)試的 mapperLocations 的值也是 classpath*:mapper/*Mapper.xml ,此時我以為找到了問題的所在了,就是 yml 的配置語法對 classpath*:mapper/*Mapper.xml 解析有問題 我也對此深信不疑。

結(jié)論:開發(fā)工具沒有同步配置

在沒寫這筆記前,我還深信問題就是 yml 的語法對值帶有 冒號 的解析時,需要對值用 引號 包起來。但是在寫筆記做記錄的過程中,需要還原場景,在調(diào)試的時候,發(fā)現(xiàn)并沒有說 需要對帶有冒號的值加上引號包起來 ,這時我才想起來,會不會是 開發(fā)工具的問題,在運(yùn)行的時候,沒有把修改的配置文件同步上去 。經(jīng)過多次的調(diào)試,也證明了這點,有時候項目跑太久,開發(fā)工具就會突然出來發(fā)難。

搞了半天, 在 application.yml 的配置 classpath*:mapper/*Mapper.xml 是有效的?。。∮行У模。?!有效的?。?! 相當(dāng)于開發(fā)工具的作祟讓我白白浪費(fèi)了2天時間,但是期間也發(fā)現(xiàn)了自身的一下問題,太久沒有遇到錯誤,一味的相信搜索引擎而不去思考,最后還差點 用錯誤的認(rèn)識,否定了原本正確的東西 。

#mapper plusmybatis-plus: mapper-locations: classpath*:mapper/*Mapper.xml

在發(fā)現(xiàn) application.yml配置修改后沒生效的第一時間,我就應(yīng)該檢查發(fā)布路徑的文件,或者去調(diào)試源碼。中間浪費(fèi)太多的時間陷入盲目的必應(yīng)搜索答案,做筆記反省一下自己,安定就會退步,堅持學(xué)習(xí),永遠(yuǎn)不要放棄思考。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 国产成人 免费观看 | 国产高清无专砖区2021 | 欧美人成片免费看视频不卡 | 香蕉自拍视频 | 日本特一级毛片免费视频 | 亚洲加勒比久久88色综合1 | 亚洲综合精品一区二区三区中文 | 日韩午夜免费视频 | 久久有这有精品在线观看 | 成人人免费夜夜视频观看 | 欧美一级毛片片免费 | 久久99久久99精品免观看 | 亚洲午夜大片 | 91久久免费视频 | 欧美成人高清免费大片观看 | 欧美精品久久久久久久免费观看 | 亚洲看片网 | 成年女人色毛片免费 | avtt天堂网 手机资源 | 国产精品久久久久影院色 | 国产精品视频久久 | 日本www免费视频网站在线观看 | 欧美精品在线免费观看 | 九九国产在线观看 | 国产在线一区二区 | 在线欧美日韩精品一区二区 | 在线视频观看免费视频18 | 国产成人免费高清在线观看 | 亚洲3p| 男人的亚洲天堂 | 和老外3p爽粗大免费视频 | 美女被男人cao的爽视频黄 | 亚洲一区二区三区免费视频 | 亚洲在线视频观看 | 日本欧美一区二区三区视频 | 九七在线视频 | 欧美在线 | 欧美 | 日本a级三级三级三级久久 日本a级特黄三级三级三级 | 亚洲a级片在线观看 | 久草国产在线视频 | 曰本一区|