Java8的groupBy實現集合的分組


場景:
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#


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM