Mapper類中存在名稱相同的方法重載報(bào)錯(cuò)問題
Mapper類中存在名稱相同的方法重載報(bào)錯(cuò)
項(xiàng)目場(chǎng)景
官網(wǎng)項(xiàng)目開發(fā)
問題描述
Mapper類中存在名稱相同的方法重載報(bào)錯(cuò)
為了省事,直接在mapper層通過@select@update等注解形式寫sql (此時(shí)大都是單表查詢沒有創(chuàng)建mapper.xml文件)代碼如下:
?? ?@Update("") ? ? void updateSortBySort(Integer newSort, Integer platform, Integer classification); ? ? @Update("") ? ? void updateSortBySort(Integer oldSort, Integer newSort, Integer platform, Integer classification);
此時(shí)可以正常使用
接下來因?yàn)闃I(yè)務(wù)原因,需要進(jìn)行多表查詢,僅使用mybatis自帶的不行,需要使用mapper.xml文件寫sql腳本,進(jìn)行多表查詢
?? ?@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);
此時(shí)調(diào)用第一個(gè)updateSortBySort方法的接口,會(huì)報(bào)一個(gè)“Parameter ‘oldSort’ not found 就是參數(shù)不存在的錯(cuò)誤”
原因分析
找到了原因:在使用@Select等注解的情況下,方法名即為mapper的id,id相同。重載的方法會(huì)報(bào)這個(gè)錯(cuò)
假如項(xiàng)目啟動(dòng)時(shí)候通過反射獲取mapper方法數(shù)組順序先是在第一個(gè)
此時(shí)調(diào)用方法,正常,不會(huì)有問題;
因?yàn)閙ybatis查找mapper內(nèi)的方法是靠方法名,和參數(shù)無關(guān)。方法名就是mapper.xml里面的id一樣
當(dāng)不進(jìn)行方法的重載時(shí),即:每個(gè)方法都有唯一的命名時(shí),在xml中進(jìn)行映射后,就可以執(zhí)行,不會(huì)出現(xiàn)異常。
所以mybatis中mapper.xml是不會(huì)準(zhǔn)確映射到Java中的重載方法的。最好不要在mapper接口中使用方法重載。
方法重載和方法重寫的區(qū)別
方法的重載的規(guī)則
- 方法名必須相同
- 參數(shù)列表必須不同(個(gè)數(shù)不同、或類型不同、參數(shù)排列順序不同等)
- 方法的返回類型可以相同也可以不相同
- 僅僅返回類型不同不足以成為方法的重載
重載就是在一個(gè)類中,有相同的函數(shù)名稱,但形參不同的函數(shù)
方法名相同時(shí),編譯器會(huì)根據(jù)調(diào)用方法的參數(shù)個(gè)數(shù)、參數(shù)類型等去逐個(gè)匹配,以選擇對(duì)應(yīng)的方法,如果匹配失敗,則編譯器報(bào)錯(cuò)
方法的重寫
- 方法名必須相同
- 參數(shù)列表必須相同
- 修飾符:范圍可以擴(kuò)大但不能縮小 :public>protect>default>private
重寫:子類的方法和父類必須一致,方法體可以不同。需要有繼承關(guān)系,子類重寫父類方法
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java date format時(shí)間格式化操作示例
這篇文章主要介紹了Java date format時(shí)間格式化操作,結(jié)合具體實(shí)例形式分析了java針對(duì)日期時(shí)間進(jìn)行格式化操作的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-03-03Java中對(duì)null進(jìn)行強(qiáng)制類型轉(zhuǎn)換的方法
小編對(duì)null進(jìn)行強(qiáng)轉(zhuǎn)會(huì)不會(huì)拋錯(cuò),非常的好奇,下面小編通過實(shí)例代碼給大家介紹Java中對(duì)null進(jìn)行強(qiáng)制類型轉(zhuǎn)換的方法,感興趣的朋友參考下吧2018-09-09Security中的@PostAuthorize、@PreFilter和@PostFilter詳解
這篇文章主要介紹了Security中的@PostAuthorize、@PreFilter和@PostFilter詳解,@PostAuthorize是在方法調(diào)用完成后進(jìn)行權(quán)限檢查,它不能控制方法是否能被調(diào)用,只能在方法調(diào)用完成后檢查權(quán)限決定是否要拋出AccessDeniedException,需要的朋友可以參考下2023-11-11一文學(xué)透ApplicationContext繼承接口功能及與BeanFactory區(qū)別
這篇文章主要為大家介紹了ApplicationContext繼承接口功能及與BeanFactory區(qū)別示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04使用ShardingJDBC進(jìn)行數(shù)據(jù)分片以及讀寫分離
ShardingJDBC是一個(gè)輕量級(jí)的Java框架,提供了數(shù)據(jù)分片、讀寫分離、分布式主鍵生成等數(shù)據(jù)訪問功能,本文將給大家介紹如何使用ShardingJDBC進(jìn)行數(shù)據(jù)分片以及讀寫分離,需要的朋友可以參考下2024-01-01