Mabitis结果集转map

需求:给定一组日期,查出每个日期所在范围内的周,并将数据与该日期组成map一同返回,key -> 日期,value -> week
在这里插入图片描述

MPST1001DAO.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >

<mapper namespace="com.faw_qm.erpcg.mps.mps.MPST1001.dao.MPST1001DAO">

    <resultMap id="mapResultLong" type="java.util.HashMap">
        <result property="key" column="k" javaType="string" jdbcType="VARCHAR"/>
        <result property="value" column="v" javaType="string" jdbcType="VARCHAR"/>
    </resultMap>

    <select id="getWeekMapByDate" resultMap="mapResultLong">
        <foreach item="item" index="index" collection="list"  separator=" union all " >
            SELECT
            #{item} AS k ,
            `week` v
            FROM
            `ompslaborcal`
            WHERE
            startDate <![CDATA[ <= ]]> #{item} AND endDate <![CDATA[ >= ]]>  #{item}
        </foreach>
    </select>
</mapper>

MPST1001DAO


@Mapper
@Repository
public interface MPST1001DAO {
    Map<String, String> getWeekMapByDate(@Param("list") Collection ids);
}

定义查询结果转换器
MapResultHandler

public class MapResultHandler implements ResultHandler {
    private final Map mappedResults = new HashMap();

    @Override
    public void handleResult(ResultContext context) {
        @SuppressWarnings("rawtypes")
        Map map = (Map)context.getResultObject();
        mappedResults.put(map.get("key"), map.get("value"));
    }

    public Map getMappedResults() {
        return mappedResults;
    }
}

自定义SessionMapper,获取连接执行MPST1001DAO层方法,调用结果处理器处理结果
SessionMapper

@Repository
public class SessionMapper extends SqlSessionDaoSupport {

    @Resource
    public void setSqlSessionFactory(SqlSessionFactory sqlSessionFactory) {
        super.setSqlSessionFactory(sqlSessionFactory);
    }

    @SuppressWarnings("unchecked")
    public Map<String, String> getWeekMapByDate(Collection list) {
        MapResultHandler handler = new MapResultHandler();
        this.getSqlSession().select(MPST1001DAO.class.getName() + ".getWeekMapByDate", list, handler);
        Map<String, String> map = handler.getMappedResults();
        return map;
    }
}

注入SessionMapper之后调用



@Service
public class MPST1001ServiceImpl implements MPST1001Service {

    @Autowired
    private SessionMapper dao;

    @Override
    public String getWeekMapByDate(String str) {
        Map<String, String> houseMapByAreaId = dao.getWeekMapByDate(new ArrayList(Arrays.asList("2021-01-13", "2021-01-05")));
        return JSON.toJSONString(houseMapByAreaId);
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值