是这样的,我在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中的字段是不一样的,前者有的,后者没有。
请问各位大神,这怎么解释?