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ù)無關(guān)。方法名就是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
重寫:子類的方法和父類必須一致,方法體可以不同。需要有繼承關(guān)系,子類重寫父類方法
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Security中的@PostAuthorize、@PreFilter和@PostFilter詳解
這篇文章主要介紹了Security中的@PostAuthorize、@PreFilter和@PostFilter詳解,@PostAuthorize是在方法調(diào)用完成后進行權(quán)限檢查,它不能控制方法是否能被調(diào)用,只能在方法調(diào)用完成后檢查權(quán)限決定是否要拋出AccessDeniedException,需要的朋友可以參考下2023-11-11一文學透ApplicationContext繼承接口功能及與BeanFactory區(qū)別
這篇文章主要為大家介紹了ApplicationContext繼承接口功能及與BeanFactory區(qū)別示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-04-04使用ShardingJDBC進行數(shù)據(jù)分片以及讀寫分離
ShardingJDBC是一個輕量級的Java框架,提供了數(shù)據(jù)分片、讀寫分離、分布式主鍵生成等數(shù)據(jù)訪問功能,本文將給大家介紹如何使用ShardingJDBC進行數(shù)據(jù)分片以及讀寫分離,需要的朋友可以參考下2024-01-01