mybatisPlus返回Map类型的集合

 更新时间:2023年03月17日 10:07:35   作者:林卓淇  
本文主要介绍了mybatisPlus返回Map类型的集合,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

1、自定义实现该类

package com.linmain.dict.handle;
import org.apache.ibatis.session.ResultContext;
import org.apache.ibatis.session.ResultHandler;
import java.util.HashMap;
import java.util.Map;
/**
 * @Author linzhuoqi
 * @Date 2023/3/9
 * @Eamil 1580752420@qq.com
 * @Version
 * @Description  新建一个mappedResults,每次感应到数据进来,处理下然后塞进去。
 */
@SuppressWarnings("all")
public class MapResultHandle<K, V> implements ResultHandler<Map<K, V>> {

    private final Map<K,V> mappedResults = new HashMap<>();
    
    @Override
    public void handleResult(ResultContext<? extends Map<K, V>> resultContext) {
        Map map = (Map) resultContext.getResultObject();
        //key和value是xml中映射的
        mappedResults.put((K)map.get("key"), (V)map.get("value"));
    }

    public Map<K, V> getMappedResults() {
        return mappedResults;
    }
}

2、在抽象dao层书写返回map集合类型的方法

Map<String,String> pageByTypeId(Serializable typeId);

3、在XXXDao.xml文件中书写sql语句和resultMap类型

 <!-- result类型 -->
 <resultMap id="mapResult" type="java.util.HashMap">
     <result property="key" column="data_value"/>
     <result property="value" column="data_name"/>
 </resultMap>

 <!-- 上述方法的sql语句 -->
 <select id="pageByTypeId" resultMap="mapResult">
     select data_name, data_value
     from dict_data
     where dict_id = #{typeId}
       and is_delete = '0';
 </select>

4、如何使用

 @Override
 public Map<String,String> getAllByTypeId(Serializable typeId) {
     //获取一个sqlsession对象,true:自动提交
     SqlSession sqlSession = sqlSessionFactory.openSession(true);

     //创建一个结果处理器
     MapResultHandle<String, String> mapResultHandle = new MapResultHandle<>();

     //进行数据查询和结果封装
     sqlSession.select("com.linmain.dict.dao.DictDataDao.pageByTypeId", typeId, mapResultHandle);
     Map<String, String> mappedResults = mapResultHandle.getMappedResults();
     return mappedResults;
    }

到此这篇关于mybatisPlus返回Map类型的集合的文章就介绍到这了,更多相关mybatisPlus返回Map类型的集合内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解springboot springsecuroty中的注销和权限控制问题

    详解springboot springsecuroty中的注销和权限控制问题

    这篇文章主要介绍了springboot-springsecuroty 注销和权限控制,账户注销需要在SecurityConfig中加入开启注销功能的代码,权限控制要导入springsecurity和thymeleaf的整合依赖,本文通过实例代码给大家介绍的非常详细,需要的朋友参考下吧
    2022-03-03
  • 使用Maven打包时包含资源文件和源码到jar的方法

    使用Maven打包时包含资源文件和源码到jar的方法

    这篇文章主要介绍了使用Maven打包时包含资源文件和源码到jar的方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • 学会Java字节码指令,成为技术大佬

    学会Java字节码指令,成为技术大佬

    Java 字节码指令是 JVM 体系中非常难啃的一块硬骨头,我估计有些读者会有这样的疑惑,“Java 字节码难学吗?我能不能学会啊?”本文带领大家一探究竟,帮助大家搞懂java底层代码如何执行
    2021-08-08
  • Java编程用两个栈实现队列代码分享

    Java编程用两个栈实现队列代码分享

    这篇文章主要介绍了Java编程用两个栈实现队列代码分享,具有一定参考价值,这里给大家分享下,供需要的朋友了解。
    2017-10-10
  • JSP代码实现 金字塔(倒置)示例

    JSP代码实现 金字塔(倒置)示例

    这篇文章主要介绍了JSP代码实现 金字塔(倒置)示例,需要的朋友可以参考下
    2014-02-02
  • 详解SpringCloud微服务架构之Hystrix断路器

    详解SpringCloud微服务架构之Hystrix断路器

    本篇文章主要介绍了详解SpringCloud微服务架构之Hystrix断路器,Hystrix是一个库,通过添加延迟容差和容错逻辑来帮助您控制这些分布式服务之间的交互,有兴趣的可以了解一下
    2018-01-01
  • 解决spring security中遇到的问题

    解决spring security中遇到的问题

    这篇文章主要介绍了解决spring security中遇到的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • Java反射机制,反射相关API,反射API使用方式(反射获取实体类字段名和注解值)

    Java反射机制,反射相关API,反射API使用方式(反射获取实体类字段名和注解值)

    这篇文章主要介绍了Java反射机制,反射相关API,反射API使用方式(反射获取实体类字段名和注解值),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • Java链表(Linked List)基本原理与实现方法入门示例

    Java链表(Linked List)基本原理与实现方法入门示例

    这篇文章主要介绍了Java链表(Linked List)基本原理与实现方法,结合实例形式分析了Java链表(Linked List)的功能、原理、实现方法与操作注意事项,需要的朋友可以参考下
    2020-03-03
  • Java超详细透彻讲解static

    Java超详细透彻讲解static

    static关键字基本概念我们可以一句话来概括:方便在没有创建对象的情况下来进行调用。也就是说:被static关键字修饰的不需要创建对象去调用,直接根据类名就可以去访问,让我们来了解一下你可能还不知道情况
    2022-05-05

最新评论