ArrayList按照某個屬性進行分組(轉)這個寫的好!

https://blog.csdn.net/linsongbin1/article/details/54341078

通常使用SQL查詢一批數據的時候,可以利用SQL中的GROUP BY語句對數據進行分組,但是有時候出於對性能的考慮,不會使用GROUP BY,而是先把數據撈出來後,使用代碼,在內存中按照某個屬性進行分組。

 

public class TestArrayListGroupByKey {

    public static void main(String[] args) {
        /*1、準備數據**/
        SkuVo sku1 = new SkuVo(1L,"p1",100L);
        SkuVo sku2 = new SkuVo(2L,"p2",101L);
        SkuVo sku3 = new SkuVo(3L,"p3",102L);
        SkuVo sku4 = new SkuVo(3L,"p4",103L);
        SkuVo sku5 = new SkuVo(2L,"p5",100L);
        SkuVo sku6 = new SkuVo(5L,"p6",100L);

        List<SkuVo> skuVoList = Arrays.asList(new SkuVo [] {sku1,sku2,sku3,sku4,sku5,sku6});

        /*2、分組算法**/
        Map<Long, List<SkuVo>> skuIdMap = new HashMap<>();
        for (SkuVo skuVo : skuVoList) {
            List<SkuVo> tempList = skuIdMap.get(skuVo.getSkuId());
            /*如果取不到數據,那麼直接new一個空的ArrayList**/
            if (tempList == null) {
                tempList = new ArrayList<>();
                tempList.add(skuVo);
                skuIdMap.put(skuVo.getSkuId(), tempList);
            }
            else {
                /*某個sku之前已經存放過了,則直接追加數據到原來的List裏**/
                tempList.add(skuVo);
            }
        }

        /*3、遍歷map,驗證結果**/
        for(Long skuId : skuIdMap.keySet()){
            System.out.println(skuIdMap.get(skuId));
        }
    }
}
--------------------- 
作者:Sam哥哥 
來源:CSDN 
原文:https://blog.csdn.net/linsongbin1/article/details/54341078 
版權聲明:本文爲博主原創文章,轉載請附上博文鏈接!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章