我想使用 Java 8 Stream API 以非静态方法将 Java POJO 列表转换为 Map。
我的折线图需要轴 x 的日期字符串值列表和轴 y 的数值列表。这是一种典型的地图格式。但是我的数据库为我返回了一个 POJO 列表。如果没有 Java 8 Stream API 的帮助,我不喜欢循环。我已经尝试了这个 [ask}(Java 8 List of Objects to Map<String, List> of values)中的方法。但是,我面临两个问题。首先,我的 POJO MoreCustomDTO 除了 String 之外还包含 Integer。其次,当我尝试使用方法引用时,IDEA 抱怨无法从静态上下文中引用非静态方法。
POJO:
@Data
MoreCustomDTO {
private String date;
private Integer money;
}
DAO查询方法:
public List<MoreCustomDTO > getMoreCustomCount(@Param("format") String format, @Param("startTime") String startTime, @Param("endTime") String endTime);
Java 8 之前的解决方案:
List<MoreCustomCountDTO> customList = customDao.getMoreCustomCount(SqlUtils.DATE_TYPE_FORMAT[Integer.valueOf(type)],startTime,endTime);
Map<String, List> map = new HashMap();
List<String> dateList = new ArrayList<>();
List<Integer> moneyList = new ArrayList<>();
for (MoreCustomCountDTO data : customList) {
dates.add(data.getDate());
dailyAmounts.add(data.getMoney());
}
map.put("date", dateList);
map.put("money", moneyList);
故障代码段:
Map<String,List> map =
customList.stream()
.flatMap(element -> {
Map<String,String> um = new HashMap<>();
um.put("date",element.getDate());
um.put("money",element.getMoney());
return um.entrySet().stream();
})
.collect(Collectors.groupingBy(Map.Entry::getKey,
Collectors.mapping(Map.Entry::getValue,
Collectors.toList())));
我从我的数据库中得到一个列表。它是 JSON 格式的对象数组。
回复:
{
"rows": [
{
"date": "2019-09-01",
"money": 0.00
},
{
"date": "2019-09-02",
"money": 0.00
}
]
}
但我想要一个(键)对多(值)映射格式。
回复:
{
"map": {
"date": [
"2019-09-01",
"2019-09-02"
],
"money": [
0.00,
0.00
]
}
}