欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis中方法返回泛型與resultType不一致的解決

 更新時間:2021年07月30日 12:05:40   作者:孫艷強  
這篇文章主要介紹了mybatis中方法返回泛型與resultType不一致的解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

mybatis方法返回泛型與resultType不一致

當(dāng)xxxMaaper.java的方法返回值類型是List<A>,而xxxMappper.xml中對應(yīng)的sql的resultType指定為B對象,這樣是不會包錯的(即使A與B不存在關(guān)系)

原因分析:

1.集合對象原本就是存儲對象,可以是不同的對象List

2.直接處理List類型常常會出現(xiàn)類型轉(zhuǎn)換異常,jdk5出現(xiàn)泛型,使得程序員向list中存放相同類型對象

3.泛型作用于編譯階段,僅為了防止類型混亂而出現(xiàn),類型轉(zhuǎn)換異常

4.mybatis結(jié)果集封裝bean時采用反射,是在運行時進行的,此時再看泛型容易進入誤區(qū)

實例:

public class A
}
public class B{
}
@Service()
public class AImpl implements AService {
private AMapper  aMapper ;
public List<B> increTrade(Map<String, Object> map) {
List<B> lst =aMapper.increTrade(map); //這里debug看到list是A類型,此時泛型誤導(dǎo)人
return lst;
}
}
public interface AMapper {
List<B>increTrade(Map<String, Object> map);
}

AMapper 對應(yīng)的xml文件

<select id="increTrade" parameterType="java.util.Map" resultType="cn.easier.admin.model.A">
//-------------
</select>

List中map泛型對應(yīng)mybatis的返回類型

List<Map<String,Object>>在mybatis對應(yīng)

resultType="java.util.HashMap"
</select>
  <select id="selectExceptionCountBymonths" resultType="java.util.HashMap"  >
SELECT
 DATE_FORMAT( report_date, '%Y%m' ) label ,
 COUNT( 0 ) value
FROM
 t_smoke_detector_record
 WHERE tsdr_type != "火災(zāi)告警"
GROUP BY
 label
 
  </select>
@ApiOperation(value = "按照月份統(tǒng)計報警條數(shù)",notes = "按照月份統(tǒng)計報警條數(shù)")
@GetMapping(value = "warnCountStatistics")
@ActionLog(value = "按照月份統(tǒng)計所有報警條數(shù)")
    public  List<Map<String,Object>>  warnCountStatistics(){
        List list = smokeDetectorRecordMapper.selectWarnCountBymonths();
        return list;

返回結(jié)果

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論