mybatis返回map结果集 key value_java map.entry

mybatis返回map结果集 key value_java map.entry原文:http://blog.csdn.net/sou_liu/article/details/47755635最近需要用到Mybatis中查询结果集为Map的功能,查了好多资料,最终搞定。其实只需要重写ResultHandler接口,,然后用SqlSession的select方法,将xml里面的映射文件的返回值配置成HashMap就可以了。具体过程如下1、先看看

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

Jetbrains全系列IDE稳定放心使用

其实只需要重写ResultHandler接口,,然后用SqlSession 的select方法,将xml里面的映射文件的返回值配置成 HashMap 就可以了。具体过程如下

1、先看看xml文件怎么配置

 

[html] 

 

  1. <resultMap id=“getAllSetDaysResult”   type=“HashMap”>  
  2.     <result property=“key” column=“SP_FPARAMEKEY” />  
  3.     <result property=“value” column=“SP_FPARAMEVALUE” />  
  4.           
  5. </resultMap>  

 

来看看sql是怎么写的

 

[html]

 

  1. <select id=“getAllSetDays” resultMap=“getAllSetDaysResult”>  
  2. SELECT SP.FPARAMEKEY SP_FPARAMEKEY, SP.FPARAMEVALUE SP_FPARAMEVALUE   
  3.   FROM T_SERVER_PARAMETER SP  
  4.  WHERE SP.FPARAMEKEY IN (‘XXX’)  
  5. </select>  

这里面的property属性列的值,就是你后面实现的ResultHandler 接口返回的map集的key和value,具体看代码

 

2、重写org.apache.ibatis.session 中ResultHandler接口:

 

[java] 

 

  1. public class FblMapResultHandler implements ResultHandler {  
  2.     @SuppressWarnings(“rawtypes”)  
  3.     private final Map mappedResults = new HashMap();  
  4.   
  5.     @SuppressWarnings(“unchecked”)  
  6.     @Override  
  7.     public void handleResult(ResultContext context) {  
  8.         @SuppressWarnings(“rawtypes”)  
  9.         Map map = (Map) context.getResultObject();   
  10.         mappedResults.put(map.get(“key”), map.get(“value”));  // xml 配置里面的property的值,对应的列  
  11.     }  
  12.     public Map getMappedResults() {    
  13.         return mappedResults;    
  14.     }    
  15. }  

3、调用select方法:

 

[java] 

 

  1.        FblMapResultHandler fbl = new FblMapResultHandler();  
  2. getSqlSession().select(NAMESPACE +“getAllSetDays”,fbl);  
  3. @SuppressWarnings(“rawtypes”)  
  4. Map map =fbl.getMappedResults();  
  5. return map;  

此时map里面的key,和value就是我们数据库中表中的对应的两列了.

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • jenkins自定义构建参数_git将本地新建的分支提交到远程

    jenkins自定义构建参数_git将本地新建的分支提交到远程前言当我们的自动化项目越来越多的时候,在代码仓库会提交不同的分支来管理,在用jenkins来构建的时候,我们希望能通过参数化构建git仓库的分支。下载安装GitParameter插件系统管理-

    2022年7月29日
    12
  • cxf 注解_cancel缩写为什么是CXL

    cxf 注解_cancel缩写为什么是CXLhttp://blog.csdn.net/look85927/article/details/13000117

    2025年5月31日
    3
  • CSDN有哪些值得学习的专栏?

    CSDN有哪些值得学习的专栏?马上2020年了,回顾2019这一年,CSDN哪些专栏受到了大家的喜爱呢?我们结合专栏的关注量、浏览量、用户反馈等多个方面,精选出一些专栏,分期分类推荐给你!涉及各类领域,带你从入门进阶实战!目录一、Java二、Python新三、C/C++四、AI五、OpenCV六、SpringBoot七、GO新八、其他新一、Java1、Java程序…

    2022年9月1日
    5
  • linux中vi编辑器保存文件命令_linux用vi编辑文件

    linux中vi编辑器保存文件命令_linux用vi编辑文件工具:Linux方法:1、首先进入Linux的命令行界面.在目录下创建一个用于测试的文本文件(touchfilename).这里就新建了一个test12文本文件.当然这个名字是可以随便取得.2、用”vitest12″命令进入vi命令行模式(vifilename).如果要想编辑文本文件.必须要转换到插入模式下,也就是按一下键盘上的”i”就可以了.这样就可以编辑文本,删除文本中的内容.按键盘上…

    2022年9月22日
    4
  • 自监督:对比学习contrastive learning「建议收藏」

    自监督:对比学习contrastive learning「建议收藏」对比自监督学习英文原文对比自监督学习导读利用数据本身为算法提供监督。对比自监督学习技术是一种很有前途的方法,它通过学习对使两种事物相似或不同的东西进行编码来构建表示。自监督方法将取代深度学习中占主导地位的直接监督范式的预言已经存在了相当一段时间。AlyoshaEfros打了一个著名的赌,赌在2015年秋季之前,一种无监督的方法将会在检测PascalVOC方面胜过有监督的R-CNN。但四年之后,他的预言现在已经实现了。目前,自监督方法(MoCo,Heetal.,2019)在Pasc

    2025年11月13日
    5
  • postgresql 索引类型[通俗易懂]

    postgresql 索引类型[通俗易懂]postgresql提供了B-tree,R-tree,GiST和hash索引类型。不同的索引类型适合特定的查询类型。绝大多数数据库都支持B-tree索引类型,postgresql默认的createindex语句也是创建B-tree索引。 R-tree:R树是一种用于处理多维数据的数据结构,用来访问二维或者更高维区域对象组成的空间数据.R树是一棵平衡树。树上有两类结点:叶子结点和非

    2022年5月25日
    139

发表回复

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

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