詳解Java8的groupBy實現集合的分組

場景:

Java8的groupBy實現集合的分組,類似Mysql的group by分組功能,註意得到的是一個map

1.對集合按照單個屬性分組

e.g. 按照skuId分組

Map<String, List<EntryDeliveryDetailywk>> detailsMap01 = dtos1.stream()
.collect(Collectors.groupingBy(EntryDeliveryDetailywk::getskuId));

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

到此這篇關於詳解Java8的groupBy實現集合的分組的文章就介紹到這瞭,更多相關Java8 groupBy集合分組內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: