一、返回map类型
Mapper.xml配置
<select id="fetchSummary" parameterType="java.util.Map" resultType="java.util.Map">
SELECT
MIN(t.d_time) "startDate",
MAX(t.d_time) "endDate",
SUM(t.n_keyword_msg_num) "keywordMsgTotal",
SUM(t.n_keyword_people_num) "keywordPeopleTotal",
SUM(t.n_non_msg_num) "nonMsgTotal",
SUM(t.n_non_people_num) "nonPeopleTotal"
FROM t_message_stat t
WHERE t.n_wid = #{wid,jdbcType=BIGINT}
</select>
Java代码
HashMap<String, Object> msgTotal = messageStatDao.fetchSummary(wid);
String startDate = msgTotal.get("startDate") + ""
二、foreach的使用1. 当查询的参数只有一个时
1) 如果参数的类型是List, 则在使用时,collection属性要必须指定为 list
findByIds(List<Long> ids)
<select id="findByIdsMap" resultMap="BaseResultMap">
Select
<include refid="Base_Column_List" />
from jria where ID in
<foreach item="item" index="index" collection="list" open="("
separator="," close=")">
#{item}
</foreach>
</select>
2) 如果参数的类型是Array,则在使用时,collection属性要必须指定为 array
findByIds(Long[] ids)
<select id="findByIdsMap" resultMap="BaseResultMap">
select
<include refid="Base_Column_List" />
from jria where ID in
<foreach item="item" index="index" collection="array" open="("
separator="," close=")">
#{item}
</foreach>
</select>
2. 当查询的参数有多个时,例如 findByIds(String name, Long[] ids)
这种情况需要特别注意,在传参数时,一定要改用Map方式, 这样在collection属性可以指定名称。下面是一个示例
Map<String, Object> params = new HashMap<String, Object>(2);
params.put("name", name);
params.put("ids", ids);
mapper.findByIdsMap(params);
<select id="findByIdsMap" resultMap="BaseResultMap">
select
<include refid="Base_Column_List" />
from jria where ID in
<foreach item="item" index="index" collection="ids" open="("
separator="," close=")">
#{item}
</foreach>
</select>