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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • vue组件通讯之$attrs

    vue组件通讯之$attrs使用场景我们会遇到这样的场景,比如对element-ui的el-table组件进行二次开发,但是el-table组件有很多属性比如控制高度的height,传入数据的data还有border、size、fit等一个个的去传显然不大现实,这个使用用$attrs处理起来就会特别优雅。举例子组件:自定义组件对el-table进行封装,用$attrs接收父组件传过来的属性<template&g…

    2022年10月18日
    0
  • pycharm的注释方法_pycharm激活教程

    pycharm的注释方法_pycharm激活教程用的pycharm,有三种注释方式:1.用一对”””括起来要注释的代码块。2.用一对”’括起来要注释的代码块。3.选中要注释的代码,按下ctrl+/注释。

    2022年8月29日
    1
  • Chrome您的连接不是私密连接解决办法–一个比较实用的技巧分享[通俗易懂]

    Chrome您的连接不是私密连接解决办法–一个比较实用的技巧分享[通俗易懂]问题:运行项目在Chrome中打开出现以下问题您的连接不是私密连接攻击者可能会试图从x.x.x.x窃取您的信息(例如:密码、通讯内容或信用卡信息)。了解详情NET::ERR_CERT_INVALID将您访问的部分网页的网址、有限的系统信息以及部分网页内容发送给Google,以帮助我们提升Chrome的安全性。隐私权政策x.x.x.x通常会使用加密技术来保护您的信息。GoogleChrome此次尝试连接到x.x.x.x时,此网站发回了异常的错误凭据。这可能是因为有攻击者在试图

    2022年5月2日
    164
  • method什么意思_method的值有哪些

    method什么意思_method的值有哪些这个报错只有IDEA会有问题,在eclipse并不会出现这个问题。有哪位前辈可以帮我指点迷津吗?publicclassServletDemo02extendsHttpServlet{privatestaticfinallongserialVersionUID=1L;publicvoiddoPost(HttpServletRequestrequest,HttpServl…

    2022年9月23日
    0
  • c++ 常量表达式_c语言所有函数

    c++ 常量表达式_c语言所有函数constexpr修饰函数。普通函数/类成员函数。1.函数必须要有返回值,并且return返回的表达式必须是常量表达式。错误代码如下:#include<iostream>usingnamespacestd;//error不是常量表达式函数constexprvoidfunc1(){ inta=200; cout<<a<<endl;}//error不是常量表达式函数因为a是变量,不是常量constexprint

    2022年9月27日
    0
  • 串口打印是什么意思_串口无法启动 代码10

    串口打印是什么意思_串口无法启动 代码10DM36xinitializationpassed!TIUBLVersion:1.50BootingCatalogBootLoader         //启动目录BootLoader                           BootMode=NAND       

    2022年8月13日
    5

发表回复

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

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