uniquewonderq
Think_Bigger
2017-10-17 03:38

【ibatis】sql的返回类型与java接受类型不一致竟然不报错!

5
  • java
  • xml
  • ibatis
  • sql

是这样的,我在sql mapper的xml中有个sql 大概长下面这样子:

 <select id="getFilesList" parameterClass="com.common.dto.UpLoadFileDTO" 
    resultClass="com.common.dto.FileListDTO">
        --...
        --...
        --...
</select> 

然后在java程序中,我是这么接受这个返回的。

 List<ArrayList<UploadFileDTO>> result = null;
        try {
            result = getCommExeSqlDAO().queryForList("getFilesList", params);
        } catch (PafaDAOException e) {
            throw new BusinessException(e);
        }

机智的你,可能一眼就看出来,接收参数类型 完全不一致
接收的参数类型是 list< list< DTO > > 格式的,而返回是
list< DTO >格式类型的。

但结果很让人吃惊,能正常执行,且返回的结果是list< FileListDTO > 类型,而且数据也是正常,正确的。
也就是说,是按照ibatis中的resultClass来的。而且这两个DTO中的字段是不一样的,前者有的,后者没有。

请问各位大神,这怎么解释?

  • 点赞
  • 回答
  • 收藏
  • 复制链接分享

4条回答