mybatis返回值_存储过程获取查询结果

mybatis返回值_存储过程获取查询结果com.jerry.mapper.TestMapper.javapackagecom.jerry.mapper;importjava.util.List;importjava.util.Map;publicinterfaceTestMapper{ /** *查寻单个结果直接返回Map<String,Object> *@paramid *…………..

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

测试数据

数据库 SQL测试数据 – 笑虾原创诗词表

查询返回单个结果

返回单个 Map

设置返回值类型 resultType="java.util.Map"

PoemMapper.xml

    <select id="selectMap" resultType="java.util.Map">
        SELECT id, title, author FROM poem LIMIT 1   
    </select>

PoemMapper.java

Map为最外层容器时就要加 @MapKey("id") 指定提取 id 作为 key

    @MapKey("id")
    Map<Long, Object> selectMap();

PoemMapperTest.java

    @Test
    public void selectMap() { 
   
        Map<Long, Object> map = poemMapper.selectMap();
        System.out.println(JSON.toJSONString(map));
    }  

输出结果

注意:Map是无序的,所以这里的字段并没有按SQL中的顺序来显示。

{ 
   "1":{ 
   "author":"笑虾","id":1,"title":"痴情癫"}}

返回单个 LinkedHashMap

用来实现按SQL中的顺序来显示字段。

PoemMapper.xml

设置返回值类型 resultType="java.util.LinkedHashMap"

    <select id="selectLinkedHashMap" resultType="java.util.LinkedHashMap">
        SELECT id, title, author FROM poem LIMIT 1
    </select>

PoemMapper.java

LinkedHashMap<String, Object> selectLinkedHashMap();    

PoemMapperTest.java

LinkedHashMap<String, Object> linkedHashMap = poemMapper.selectLinkedHashMap();

输出结果

注意:LinkedHashMap字段SQL中的顺序显示。

{ 
   "id":1,"title":"痴情癫","author":"笑虾"}

查询返回多个结果

  1. List保留住SQLORDER By的排序。
  2. LinkedHashMap保留住SQLSELECT 字段的排序。

返回 List<Map>

PoemMapper.xml

    <select id="selectMapList" resultType="java.util.Map">
        SELECT id, title, author FROM poem
    </select>

PoemMapper.java

List<Map<String, Object>> selectMapList();

PoemMapperTest.java

List<Map<String, Object>> maps = poemMapper.selectMapList();

输出结果

[
	{ 
   "author":"笑虾","id":1,"title":"痴情癫"},
	{ 
   "author":"笑虾","id":2,"title":"爱云说"},
	{ 
   "author":"笑虾","id":3,"title":"恨灯小"}, 
	略。。。
]

返回 Map<Map>

PoemMapper.xml

    <select id="selectMapMap" resultType="java.util.Map">
        SELECT id, title, author FROM poem 
    </select>

PoemMapper.java

@MapKey("id")
Map<String, Map<String, Object>> selectMapMap();

PoemMapperTest.java

Map<String, Map<String, Object>> stringMapMap = poemMapper.selectMapMap();

输出结果

{ 
   
	"1":{ 
   "author":"笑虾","id":1,"title":"痴情癫"},
	"2":{ 
   "author":"笑虾","id":2,"title":"爱云说"},
	"3":{ 
   "author":"笑虾","id":3,"title":"恨灯小"},
	略。。。
}

返回 List<LinkedHashMap>

PoemMapper.xml

    <select id="selectListLinkedHashMap" resultType="java.util.LinkedHashMap">
        SELECT id, title, author FROM poem
    </select>

PoemMapper.java

List<LinkedHashMap<String, Object>> selectListLinkedHashMap();    

PoemMapperTest.java

List<LinkedHashMap<String, Object>> linkedHashMap = poemMapper.selectListLinkedHashMap();

输出结果

[
	{ 
   "id":1,"title":"痴情癫","author":"笑虾"},
	{ 
   "id":2,"title":"爱云说","author":"笑虾"},
	{ 
   "id":3,"title":"恨灯小","author":"笑虾"},
	略。。。
]

返回 Map<LinkedHashMap>

PoemMapper.xml

    <select id="selectMapLinkedHashMap" resultType="java.util.LinkedHashMap">
        SELECT id, title, author FROM poem
    </select>

PoemMapper.java

@MapKey("id")
Map<String, LinkedHashMap<String, Object>> selectMapLinkedHashMap();

PoemMapperTest.java

Map<String, LinkedHashMap<String, Object>> mapLinkedHashMaps = poemMapper.selectMapLinkedHashMap();

输出结果

{ 
   
	"1":{ 
   "id":1,"title":"痴情癫","author":"笑虾"},
	"2":{ 
   "id":2,"title":"爱云说","author":"笑虾"},
	"3":{ 
   "id":3,"title":"恨灯小","author":"笑虾"},
	略。。。
}

统计结果返回 List<Pair<Integer, Long>> 再转 Map<Integer, Long>>

PoemMapper.xml

    <select id="countByAuthor" resultType="javafx.util.Pair">
        SELECT author,	count( id ) AS `数量` FROM	poem GROUP BY author
    </select>

PoemMapper.java

List<Pair<Integer, Long>> countByAuthor();

PoemMapperTest.java

List<Pair<Integer, Long>> list = poemMapper.countByAuthor();
Map<Integer, Long> map = list.stream()
        .collect(Collectors.toMap(Pair::getKey, Pair::getValue));

输出结果

查询结果返回的是这样的一个List<Pair>List<Map>实现也可以。

[{ 
   "key":"笑虾","value":16},{ 
   "key":"金小侠","value":3}]

还需要用Collectors.toMap转为Map才得到我们想要的最终效果。

{ 
   "笑虾":16,"金小侠":3}

参考资料

笑虾:Mybatis 查询结果返回 Optional<T>

javafx.util.Pair<K,V>
《Java8实战》 – 读书笔记 – Stream流操作2:用流收集数据:6.1 收集器简介 – toMap

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/185900.html原文链接:https://javaforall.net

(0)
上一篇 2022年10月4日 下午9:00
下一篇 2022年10月4日 下午9:00


相关推荐

  • 1191 家谱树(拓扑排序)

    1191 家谱树(拓扑排序)1 问题描述 有个人的家族很大 辈分关系很混乱 请你帮整理一下这种关系 给出每个人的孩子的信息 输出一个序列 使得每个人的孩子都比那个人后列出 输入格式第 1 行一个整数 n 表示家族的人数 接下来 n 行 第 i 行描述第 i 个人的孩子 每行最后是 0 表示描述完毕 每个人的编号从 1 到 n 输出格式输出一个序列 使得每个人的孩子都比那个人后列出 数据保证一定有解 如果有多解输出任意一解 数据范围 1 n 100 输入样例

    2025年9月7日
    7
  • 数据库备份与恢复方案「建议收藏」

    数据库备份与恢复方案「建议收藏」数据安全性随着计算机的普及和信息技术的进步,特别是计算机网络的飞速发展,信息安全的重要性日趋明显。数据备份是保证信息安全的一个重要方法。只要发生数据传输、数据存储和数据交换,就有可能产生数据故障。这时

    2022年8月4日
    6
  • OpenClaw (Clawdbot) 教程

    OpenClaw (Clawdbot) 教程

    2026年3月12日
    2
  • Spline(三次样条插值)

    Spline(三次样条插值)三次样条插值

    2026年3月18日
    1
  • mysql窗口函数用法_mysql实现窗口函数

    mysql窗口函数用法_mysql实现窗口函数一,MySQl8.0窗口函数窗口函数适用场景:对分组统计结果中的每一条记录进行计算的场景下,使用窗口函数更好;可以跟Hive的对比着看:点我,特么的花了一晚上整理,没想到跟Hive的基本一致,还不因为好久没复习博客了,淦注意:mysql因为没有array数据结构,无法像Hive一样行列进行转换;1.1窗口函数分类MySQL从8.0版本开始支持窗口函数。窗口函数的作用类似于在查询中对数据进行分组,不同的是,分组操作会把分组的结果聚合成一条记录,而窗口函数是

    2022年10月5日
    3
  • Windows 10 多出多个虚拟显示器的解决方法「建议收藏」

    Windows 10 多出多个虚拟显示器的解决方法「建议收藏」昨天更新Windows101809之后,系统中多出了4个“通用非即插即用监视器”,由于本人长期是笔记本外接显示器使用,出现这个问题后,鼠标会经常性的跑到另外的屏幕上去,甚至一些窗口会跑到其他页面上去。到NVIDIA控制面板查看之后发现多出的显示器是在核心显卡上,所以怀疑是核显的问题。其实之前也出现过类似问题,Google之后发现有人也有类似问题。尝试在任务管理器中卸载多出…

    2022年8月21日
    17

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号