欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

Mybatis返回map集合时,列的顺序与select不一致问题

时间:2022-12-28 09:39:24|栏目:JAVA代码|点击:

返回map集合,列的顺序与select不一致

<select id="queryPercentByAsset" resultType="java.util.HashMap">

将Hashmap换成LinkedHashMap即可

<select id="queryPercentByAsset" resultType="java.util.LinkedHashMap">

mybatis中返回map集合问题

关于mybatis返回map集合的操作:

1.mapper.xml中写一个查询返回map的sql

<select id="findMap" parameterType="com.sxd.swapping.domain.HuaYangArea" resultType="java.util.HashMap">
         select
            hy.uid,
            hy.area_name
        from
            hua_yang_area AS hy
        <where>
            <if test="areaPerson != null">
                AND hy.area_person &gt;= #{areaPerson}
            </if>
        </where>
    </select>

2.mapper.java 对应接收

注意,这里并不是直接使用Map<>接收,因为sql查出的不是一条数据,而是多条数据,所以是List<Map<>>接收

/**
     * mybatis  查询接收map集合
     * @param area
     * @return
     */
    List<Map<String,String>> findMap(HuaYangArea area);

3.错误写法

错误的写法就是直接读取List中的Map<>

@Override
    public Map<String, String> findMap(HuaYangArea entity) {
        List<Map<String,String>> list = huaYangAreaMapper.findMap(entity);
        Map<String,String> res = new HashMap<>();
        for (Map<String, String> stringStringMap : list) {
            System.out.println(stringStringMap.toString());
            stringStringMap.forEach((k,v)->{
                System.out.println("key:"+k+">>>value:"+v);
                res.put(k,v);
            });
        }
        return res;
    }

这样查询到的结果是:

我们需要看一哈实际List<Map<>>中到底存储的是什么

结果集中存储是按照{字段名1:字段值1,字段名2:字段值2}

而我们其实期望的是{字段值1:字段值2} 

4.正确写法

所以正确的写法应该是

@Override
    public Map<String, String> findMap(HuaYangArea entity) {
        List<Map<String,String>> list = huaYangAreaMapper.findMap(entity);
        Map<String,String> res = new HashMap<>();
        for (Map<String, String> stringStringMap : list) {
            System.out.println(stringStringMap.toString());
            String uid = null;
            String areaName = null;
            for (Map.Entry<String,String> entry:stringStringMap.entrySet()){
                if ("uid".equals(entry.getKey())){
                    uid = entry.getValue();
                }else {
                    areaName = entry.getValue();
                }
            }
            res.put(uid,areaName);
        }
        return res;
    }

返回结果:

上一篇:修改及反编译可运行Jar包实现过程详解

栏    目:JAVA代码

下一篇:深入理解Java设计模式之职责链模式

本文标题:Mybatis返回map集合时,列的顺序与select不一致问题

本文地址:http://www.codeinn.net/misctech/222387.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有