場景:
Java8的groupBy實現集合的分組,類似Mysql的group by分組功能,注意得到的是一個map
1.對集合按照單個屬性分組
e.g. 按照skuId分組
Map<String, List<EntryDeliveryDetailywk>> detailsMap01 = dtos1.stream()
.collect(Collectors.groupingBy(EntryDeliveryDetailywk::getskuId));
1
2
2對集合按照多個屬性分組
solution 1 多個屬性拼接出一個組合屬性
將多個字段拼接成一個新字段,在使用Java8的groupBy進行分組
Map<String, List<EntryDeliveryDetailywk>> detailmap = details.stream()
.collect(Collectors.groupingBy(d -> fetchGroupKey(d) ));
private String fetchGroupKey(EntryDeliveryDetailywk detail){
return detail.getSkuId().toString()
+ detail.getItemsName()
+ detail.getWarehouseId().toString()
+ detail.getSupplierId().toString();
}
solution 2 造靜態內部類
在集合元素類里構造靜態內部類(成員變量即分組的對應多個屬性)
e.g.
//靜態內部類
class Person {
public static class NameAge {
public NameAge(String name, int age) {
...
}
// 注意 重寫方法 must implement equals and hash function
}
public NameAge getNameAge() {
return new NameAge(name, age);
}
}
//分組
Map<NameAge, List<Person>> map = people.collect(Collectors.groupingBy(Person::getNameAge));
solution 3 嵌套調用Java8 groupby
注意得到也是嵌套map
Map<String, Map<Integer, List<Person>>> map = people
.collect(Collectors.groupingBy(Person::getName,
Collectors.groupingBy(Person::getAge));
//調用
map.get("Fred").get(18);
參考
https://stackoverflow.com/questions/28342814/group-by-multiple-field-names-in-java-8#