mybatisPlus返回Map类型的集合
作者:林卓淇 发布时间:2022-01-31 13:37:07
标签: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;
}
来源:https://blog.csdn.net/u011746120/article/details/129441077


猜你喜欢
- 注解实现自动装配@Autowire注解@Autowire注解,自动装配通过类型,名字如果Autowire不能唯一自动装配上属性,则需要通过@
- 1.扫描所有场景,保存并添加到Build Settings中using System.Collections;using System.Co
- Java注解(annotation)简单上手反射reflect:https://www.jb51.net/article/221282.ht
- 本文实例为大家分享了C#实现拼手气红包算法的具体代码,供大家参考,具体内容如下一、方案1:即开即中,考虑机会均等,减少金额差较大的几率可以每
- 目录前言1、什么是Filter2、过滤器实现拦截过程3、过滤器与 * 的不同之处1.过滤器:2. * :3.两者的区别:4、使用Filter
- 本文实例讲述了Android播放多张图片形成的一个动画。分享给大家供大家参考,具体如下:在Android里可以逐帧的播放图片,然后产生一种动
- 具体实现过程请看下面代码:简单的调用了一下系统的拍照功能代码如下所示://拍照的方法 private void openTakePhoto(
- StringBuilder在高性能场景下的正确用法关于StringBuilder,一般同学只简单记住了,字符串拼接要用StringBuild
- 1. Spring简介Spring是一个轻量级控制反转(IoC)和面向切面(AOP)的容器框架。2. Spring的优势 1.方便解耦, 简
- 一、引言90坦克大战,很经典的一款游戏,当年与小伙伴一人一个手柄,搬上小板凳坐在电视机前,身体时不时跟随手柄摇晃着,时而表情严肃、眉头紧锁,
- Queue接口先看下Queue的继承关系和其中定义的方法:Queue继承自Collection,Collection继承自Iterable。
- 废话不多说了,直接给大家贴代码了。package com.only.android.app;import java.io.File;impo
- Apache Dubbo是一款高性能、轻量级的开源 Java RPC 框架,它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡
- 使用场景当我们在应用的Assets目录中需要加入文件时,可以直接将源文件放入,但这样会造成打包后的apk整体过大,此时就需要将放入的文件进行
- 一、在相应的板块中开启DataBinding dataBinding {
- 介绍意图:动态地给一个对象添加一些额外的职责。就增加功能来说,装饰模式相比生成子类更灵活。主要解决:我们扩展一个类常使用继承方式实现,由于继
- 如下所示:String beginDate="1328007600000";SimpleDateFormat sdf=n
- 译者注:个人觉得用定时任务来跑垃圾回收不是很好的例子,从译者接触到的项目来看,比较常见的是用定时任务来进行非实时计算,清除临时数据、文件等。
- 一、需求分析:1、输入一个数组-----------------------------------------》程序要接收一组输入的数组,
- 详解 Java中日期数据类型的处理之格式转换的实例概要:日期以及时间格式处理,在Java中时间格式一般会涉及到的数据类型包括Calendar