本网站(662p.com)打包出售,且带程序代码数据,662p.com域名,程序内核采用TP框架开发,需要联系扣扣:2360248666 /wx:lianweikj
精品域名一口价出售:1y1m.com(350元) ,6b7b.com(400元) , 5k5j.com(380元) , yayj.com(1800元), jiongzhun.com(1000元) , niuzen.com(2800元) , zennei.com(5000元)
需要联系扣扣:2360248666 /wx:lianweikj
mybatisPlus返回Map类型的集合
sz199511 · 126浏览 · 发布于2023-03-17 +关注

本文主要介绍了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;
    }


相关推荐

PHP实现部分字符隐藏

沙雕mars · 1312浏览 · 2019-04-28 09:47:56
Java中ArrayList和LinkedList区别

kenrry1992 · 896浏览 · 2019-05-08 21:14:54
Tomcat 下载及安装配置

manongba · 957浏览 · 2019-05-13 21:03:56
JAVA变量介绍

manongba · 953浏览 · 2019-05-13 21:05:52
什么是SpringBoot

iamitnan · 1077浏览 · 2019-05-14 22:20:36
加载中

0评论

评论
不积跬步无以至千里,不积小流无以成江海!
分类专栏
小鸟云服务器
扫码进入手机网页