Mapper類中存在名稱相同的方法重載報錯問題
Mapper類中存在名稱相同的方法重載報錯
項目場景
官網(wǎng)項目開發(fā)
問題描述
Mapper類中存在名稱相同的方法重載報錯
為了省事,直接在mapper層通過@select@update等注解形式寫sql (此時大都是單表查詢沒有創(chuàng)建mapper.xml文件)代碼如下:
?? ?@Update("")
? ? void updateSortBySort(Integer newSort, Integer platform, Integer classification);
? ? @Update("")
? ? void updateSortBySort(Integer oldSort, Integer newSort, Integer platform, Integer classification);此時可以正常使用
接下來因為業(yè)務原因,需要進行多表查詢,僅使用mybatis自帶的不行,需要使用mapper.xml文件寫sql腳本,進行多表查詢
?? ?@Update("")
? ? void updateSortBySort(Integer newSort, Integer platform, Integer classification);
? ? @Update("")
? ? void updateSortBySort(Integer oldSort, Integer newSort, Integer platform, Integer classification);
? ? IPage<List<ProductVo>> getlistPage(IPage<ProductVo> page,
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? @Param("Param1")Integer Param1,
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? @Param("Param2")Integer Param2);此時調(diào)用第一個updateSortBySort方法的接口,會報一個“Parameter ‘oldSort’ not found 就是參數(shù)不存在的錯誤”
原因分析
找到了原因:在使用@Select等注解的情況下,方法名即為mapper的id,id相同。重載的方法會報這個錯
假如項目啟動時候通過反射獲取mapper方法數(shù)組順序先是在第一個
此時調(diào)用方法,正常,不會有問題;
因為mybatis查找mapper內(nèi)的方法是靠方法名,和參數(shù)無關。方法名就是mapper.xml里面的id一樣
當不進行方法的重載時,即:每個方法都有唯一的命名時,在xml中進行映射后,就可以執(zhí)行,不會出現(xiàn)異常。
所以mybatis中mapper.xml是不會準確映射到Java中的重載方法的。最好不要在mapper接口中使用方法重載。
方法重載和方法重寫的區(qū)別
方法的重載的規(guī)則
- 方法名必須相同
- 參數(shù)列表必須不同(個數(shù)不同、或類型不同、參數(shù)排列順序不同等)
- 方法的返回類型可以相同也可以不相同
- 僅僅返回類型不同不足以成為方法的重載
重載就是在一個類中,有相同的函數(shù)名稱,但形參不同的函數(shù)
方法名相同時,編譯器會根據(jù)調(diào)用方法的參數(shù)個數(shù)、參數(shù)類型等去逐個匹配,以選擇對應的方法,如果匹配失敗,則編譯器報錯
方法的重寫
- 方法名必須相同
- 參數(shù)列表必須相同
- 修飾符:范圍可以擴大但不能縮小 :public>protect>default>private
重寫:子類的方法和父類必須一致,方法體可以不同。需要有繼承關系,子類重寫父類方法
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
mybatis配置mapper-locations位置的三種方式小結(jié)
這篇文章主要給大家介紹了關于mybatis配置mapper-locations位置的三種方式,Mybatis-Plus的初衷是為了簡化開發(fā),而不建議開發(fā)者自己寫SQL語句的,但是有時客戶需求比較復雜,需要的朋友可以參考下2023-08-08
Nacos?版本不一致報錯Request?nacos?server?failed解決
這篇文章主要為大家介紹了Nacos?版本不一致報錯Request?nacos?server?failed的解決方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11
SpringBoot使用Mybatis&Mybatis-plus文件映射配置方法
這篇文章主要介紹了SpringBoot使用Mybatis&Mybatis-plus文件映射配置方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-05-05
RabbitMQ開啟SSL與SpringBoot連接測試的配置方法
本文基于 CentOS 7 + Git + OpenSSL + yum 安裝的 RabbitMQ,需要讀者提交安裝好。其他方式也可變通參考本文。對RabbitMQ開啟SSL與SpringBoot連接測試相關知識感興趣的朋友一起看看吧2022-01-01

