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就是我们数据库中表中的对应的两列了.

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 苹果开发者账号多少钱?个人/公司/企业申请费用及怎么选【都有】

    苹果开发者账号多少钱?个人/公司/企业申请费用及怎么选【都有】最近在做APP开发,APP开发已经好了,现在需要将APP上架到苹果应用市场,顺便整理了一下苹果开发者账号的申请费用,大家有需要的可以看看。苹果开发者账号费用预览:苹果账号主要分为三种:个人版,公司

  • 如何搭建谷歌离线地图服务[通俗易懂]

    如何搭建谷歌离线地图服务[通俗易懂]如何发布google离线地图及二次开发API发布时间:2018-01-17版权:相关教程:一键离线地图发布(工具下载)使用教程谷歌离线地图API接口文档及接口调用实例1.说明离线地图开发环境支持谷歌地图、百度地图、高德地图等等所有常用地图类型,支持在局域网内的地图部署、二次开发。2.实现第一步:下载安装离线地图开发环境BIEGMAP离线地图服务器…

  • traceroute命令讲解

    traceroute命令讲解  通过traceroute我们可以知道信息从你的计算机到互联网另一端的主机是走的什么路径。当然每次数据包由某一同样的出发点(source)到达某一同样的目的地(destination)走的路径可能会不一样,但基本上来说大部分时候所走的路由是相同的。linux系统中,我们称之为traceroute,在MS Windows中为tracert。 traceroute通过发送小的数据包到目的设备直到其…

  • 分块矩阵计算行列式三板斧

    分块矩阵计算行列式三板斧第一板斧:上下三角分块第二板斧:对角为0零的分块第三板斧:全分块小招:A^2-B^2其他招式:利用特征值计算行列式

  • es 其实是不是就是数据库_初识ES数据库「建议收藏」

    es 其实是不是就是数据库_初识ES数据库「建议收藏」一、什么是Elasticsearch1、概念以及特点1、Elasticsearch和MongoDB/Redis/Memcache一样,是非关系型数据库。是一个接近实时的搜索平台,从索引这个文档到这个文档能够被搜索到只有一个轻微的延迟,企业应用定位:采用RestfulAPI标准的可扩展和高可用的实时数据分析的全文搜索工具。2、可拓展:支持一主多从且扩容简易,只要cluster.name一致且在同一…

  • uni-app USB连接真机测试[通俗易懂]

    uni-app USB连接真机测试[通俗易懂]1、连接手机到电脑,允许开发调试当现在红框的内容就说明连接上了2、制作自定义基座3、选择自定义基座4、运行

发表回复

您的电子邮箱地址不会被公开。

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