淺談Springboot下引入mybatis遇到的坑點
一、 springBoot + Mybatis
配置完成后,訪問數(shù)據(jù)庫遇到的問題

首先出現(xiàn)這個問題,肯定是xml文件與mapper接口沒有匹配上,甚至是xml文件根本沒有被掃描到。
于是會從配置上進行檢查:
1、 xml中的namespace命名是否與mapper接口路徑一致,需保證一致。
2、 application.properties或者application.yml文件中配置mybatis的屬性對否,如下:

第一行 typeAliasesPackage是實體類的包路徑;
第二行mapperLocations:是Mapper的xml文件存放的位置,當xml文件跟對應的Mapper接口處于同一位置的時候可以不用指定
該屬性的值。
3、 啟動類上加注解,如下:

推薦用這種方式掃描Mapper接口,另一種方式是在每一個mapper接口類上加注解

注意,上述兩種方式,必須有一種實現(xiàn),不然無法啟動項目,會報mapper接口未注入,如下:

綜上,只要上面幾種情況都配置正確,一般就可以正常啟動,并訪問數(shù)據(jù)庫。
二、 springBoot + MybatisPlus
pom中需要修改包

我用同樣的原理,準備在springBoot中引入mybatisPlus,但是配置都檢查了,依舊報類似的錯誤:

于是根據(jù)報錯的信息,究其源碼:
1、 首先由于mybatis通過mapper接口來invoke具體的方法實現(xiàn),其查詢的key是接口包名加方法名,如果找不到該key,就會報錯,具體代碼如下:

只有在configuration中找到了匹配的key,才會返回key對應的MappedStatement; 同樣調用selectById,可看到一下結果,能夠找到。很明顯而由于上面的selectById1方法是自定義實現(xiàn)的,其xml未被掃描到,還是配置的問題。

然后,再看源碼,為何configuration中找不到自定義的mapper方法,配置哪里有問題:

MybatisPlusAutoConfiguration是在啟動時,自動會讀取配置信息的,可以看到其中MybatisPlusProperties類型定義了前綴mybatis-plus,即只有前綴為mybatis-plus的配置信息才會被加載,而再看配置文件,如下,恍然大悟,mybatis的配置前綴寫錯了,修改成mybatis-plus,成功了?。?!

后來發(fā)現(xiàn),原來這跟開頭pom文件中導入的包版本有關系,
總結如下:
若使用的是mybatis,則要導入的包是下面這個,并且配置文件中mybatis的配置前綴是“mybatis”。

而若使用的是mybatis-plus,則需要導入的包是下圖,并且配置中mybatis的配置前綴是“mybatis-plus”。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
mybatis insert 返回自增主鍵的實現(xiàn)示例
mybatis 在新增之后怎么也獲取不到自增主鍵,本文主要介紹了mybatis insert 返回自增主鍵的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下2024-06-06
MybatisPlus實現(xiàn)數(shù)據(jù)權限隔離的示例詳解
Mybatis Plus對Mybatis做了無侵入的增強,非常的好用,今天就給大家介紹它的其中一個實用功能:數(shù)據(jù)權限插件,感興趣的可以跟隨小編一起了解下2024-04-04
HttpClient的RedirectStrategy重定向處理核心機制
這篇文章主要為大家介紹了HttpClient的RedirectStrategy重定向處理核心機制源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-10-10
SpringBoot實現(xiàn)XSS攻擊防御的幾種方式
隨著Web應用的普及,網(wǎng)絡安全問題也日益凸顯,跨站腳本攻擊(Cross-Site Scripting,簡稱XSS)是一種常見的Web安全漏洞,本文旨在探討如何在Spring Boot應用程序中有效地防御XSS攻擊,我們將介紹兩種主要的防御手段:注解和過濾器,需要的朋友可以參考下2024-07-07
詳解MyBatis的動態(tài)SQL實現(xiàn)原理
MyBatis提供了強大的動態(tài)SQL語句生成功能,以應對復雜的業(yè)務場景,本篇文章將結合MyBatis解析SQL語句的過程對MyBatis中對<if>,<where>,<foreach>等動態(tài)SQL標簽的支持進行分析,需要的朋友可以參考下2023-07-07

