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

 更新时间:2022年01月20日 10:43:52   作者:shenzhou_yh  
这篇文章主要介绍了Mybatis返回map集合时,列的顺序与select不一致问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

返回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;
    }

返回结果:

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java实现简单计算器小程序

    Java实现简单计算器小程序

    这篇文章主要为大家详细介绍了Java实现简单计算器小程序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • Java连接数据库JDBC技术之prepareStatement的详细介绍

    Java连接数据库JDBC技术之prepareStatement的详细介绍

    这篇文章主要介绍了Java连接数据库JDBC技术之prepareStatement的详细介绍,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • Spring Security 实现短信验证码登录功能

    Spring Security 实现短信验证码登录功能

    这篇文章主要介绍了Spring Security 实现短信验证码登录功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-05-05
  • RedisTemplate常用方法总结

    RedisTemplate常用方法总结

    本文主要介绍了RedisTemplate常用方法总结,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • 深入学习java并发包ConcurrentHashMap源码

    深入学习java并发包ConcurrentHashMap源码

    这篇文章主要介绍了深入学习java并发包ConcurrentHashMap源码,整个 ConcurrentHashMap 由一个个 Segment 组成,Segment 代表”部分“或”一段“的意思,所以很多地方都会将其描述为分段锁。,需要的朋友可以参考下
    2019-06-06
  • SpringBoot实现文件上传功能

    SpringBoot实现文件上传功能

    这篇文章主要为大家详细介绍了SpringBoot实现文件上传功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • java中全排列的生成算法汇总

    java中全排列的生成算法汇总

    本文给大家汇总介绍了常见的6种全排列的生成算法,包括字典序法、递增进位数制法、递减进位数制法、邻位交换法、递归类算法、元素增值法,有需要的小伙伴可以参考下
    2015-07-07
  • Spring MVC 中 AJAX请求并返回JSON的示例

    Spring MVC 中 AJAX请求并返回JSON的示例

    本篇文章主要介绍了Spring MVC 中 AJAX请求并返回JSON,具有一定的参考价值,有兴趣的可以了解一下。
    2017-01-01
  • SpringBoot集成Mybatis过程步骤图解

    SpringBoot集成Mybatis过程步骤图解

    这篇文章主要介绍了SpringBoot集成Mybatis过程步骤图解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-07-07
  • SpringBoot如何根据目录结构生成API接口前缀

    SpringBoot如何根据目录结构生成API接口前缀

    这篇文章主要介绍了SpringBoot如何根据目录结构生成API接口前缀,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02

最新评论