项目场景:
项目场景
数据表中的数据对应的格式是key-value,其中key对应多个value
理解不了,直接上图:
也就是一个key=a中,对应多个value
问题描述
输入一个集合,集合里面是是一些key,每个key对应一些value,输出一个Map<String,List<String>>数据结构的数据
Mapper层
List<Map<String, String>> getMap(@Param("id") List id);
原因分析:
首先,我们需要通过select语句查找到key对应的这些value,将这些value组成一个list。
其次,这个value如何组成一个list也是一个问题。
解决方案:
首先在对应mapper的xml文件中,编写一个可以实现获取唯一key对应的多条数据,逻辑上是没有问题的,但是如果这么直接实现,是非常麻烦的,所以选择分开做,利用pg数据库的多个字段聚合的特点,先将这些vallue拼接成一个字符串,之后再将这个字符串拆开,装入list,最后和key一并put到map中即可。
xml文件中的实现逻辑:
返回的是一个一个的Map,这些Map组成list< map >,其中dict_type是key,对应的中文名称是value,dict_value是key,对应的中文名称是value,也就是说,其实一组对应的type-value是一个Map中的两对值组成的。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ffcs.oss.dids.system.mapper.workflow.DiDictCMapper">
<select id="getMap" resultType="java.util.Map">
select dict_type, string_agg(dict_value,',') dict_value from di_dict_c where dict_type in
<foreach collection="dictType" item="dictType" open="(" close=")" separator=",">
#{dictType}
</foreach>
group by dict_type
</select>
</mapper>
service层:看注解
//前端传入一个list的key,找到每个key对应的value,
public ServiceResp getMap(List<String> dictTypes) {
ServiceResp result = ServiceResp.getInstance();
List<Map<String,String>> list = diDictCMapper.getMap(dictTypes);
Map<String, List<String>> newMap = new DiDictCService().getFinalMap(list);
result.success(newMap);
return result;
}
/**
* 1.前面说了实际上得到的list<Map<String,String>>中一个Map对应的是两对键值,
* 第一对key-value对应的是"type-中文名称",第二对对应的是"value-中文名称"
* 结果要得到的是"type的中文名称-value的中文名称",
* 解决方案:先遍历list<Map>,每次遍历一个Map,都是两对值,只要获取两个键值对的value,
* 将第一个value作为对应的type,第二个value作为对应的list的value,所以遍历List<Map>时
* ,再内嵌套一个map的遍历,即可获得一个最终的键值对
* (第二对的value得到以后需要进行分割处理,然后装入list,变成最终的value形态)
* @param list
* @return
*/
public Map<String, List<String>> getFinalMap(List<Map<String,String>> list) {
Map<String, List<String>> newMap = new HashMap<>();
int index = -1;
String first = null,Second;
String key = null,str;
String value;
for (Map<String, String> map : list) {
for (Map.Entry<String, String> m : map.entrySet()) {
index++;
str = m.getKey();
key = m.getValue();
if (index == 0) {
first = key;
} else if (index == 1) {
String[] sp = key.split(",");
List<String> end = new ArrayList<>();
for (String p : sp) {
end.add(p);
}
newMap.put(first, end);
index = -1;
}
}
}
return newMap;
}