先从mysql中查询到mList
//分页查询车辆数据
Page<?> total = PageHelper.startPage(page, rows);
List<VehistoryVO> mlist=vehicleInfoMapper.queryVehDataForhi(param);
再次分页查询Histore,批量查询,
Page<?> total = PageHelper.startPage(page, rows);
List<VehicleData> hList=vehicleDataMapper.queryBySeqs(mlist);
把hList查询的数据set到mList中统一返回前台
if(hList!=null){
for(int i=0;i<mlist.size();i++){
mlist.get(i).setData(hList.get(i));
}
}
------------------------------------------------service----------------------------------------------------------
------------------------------------------------VO----------------------------------------------------------
------------------------------------------------Mysql----------------------------------------------------------
------------------------------------------------Histore----------------------------------------------------------
======================批量查询参数List类型---报错参考如下===================
根据报错日志分析,是MyBatis在解析xml时找不到其中声明的studentNameList,但是在Dao中明明传的参数就是studentNameList,怎么会报错呢?
查询了一下MyBatis官方的说明文档,终于找到了原因,在http://mybatis.github.io/mybatis-3/zh/dynamic-sql.html#foreach里有一段说明:
因为我传的参数只有一个,而且传入的是一个List集合,所以mybatis会自动封装成Map<"list",studentNameList>。在解析的时候会通过“list”作为Map的key值去寻找。但是我在xml中却声明成studentNameList了,所以自然会报错找不到。
解决办法:
第一种就是修改mapper.xml中foreach标签内容,把studentNameList修改为list
不过这种方式我个人不太建议,因为以后如果要扩展该方法,增加集合参数的时候,还得修改xml中的内容。
第二种方式,修改dao中的参数传入方式,手动封装成map,然后把map当参数传进去
Dao方法修改为:
然后修改mapper.xml中的parameterType类型为Map