批量查询一年的数据
通常我们需要获取到某一年的数据,如果通过for循环去一条一条的查询,每次都要和获取与数据库的连接,效率显然是较为低下的,如果通过嵌套子查询即可解决该问题。
步骤
1.写出我们要进行查询的某一个月的数据格式。
2.通过foreach循环执行想查询的语句,注意:循环子查询的语句必须要有一个别名,可以通过item变量来做别名。
3.查询出来的字段也可以通过${}这种字符串拼接的方式来进行区分归类,像我这通过查询的月份来做拼接到时候取值也会更简单。
4.特别说一下CONVERT函数,因为通过AVG函数求平均值默认在myBatis转换出来时Double类型,而且会有小数位,所以将其转成decimal类型然后取整。
<select id="queryYearMonthWaitTime" resultType="hashMap">
SELECT * FROM
<foreach collection="months" item="month" separator=",">
(SELECT MONTH(off_time) avgMonth${month},CONVERT(AVG(duration_time),decimal(10,0)) avgDurationTime${month}
FROM device_em_history
WHERE YEAR (off_time) = #{year}
AND MONTH (off_time) = #{month}
AND NOT ISNULL(duration_time)) AS month${month}
</foreach>
</select>