一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - java ArrayList按照同一屬性進(jìn)行分組

java ArrayList按照同一屬性進(jìn)行分組

2020-08-13 11:49linsongbin Java教程

這篇文章主要介紹了java ArrayList按照同一屬性進(jìn)行分組的相關(guān)資料,需要的朋友可以參考下

java ArrayList按照同一屬性進(jìn)行分組

前言:

通常使用SQL查詢一批數(shù)據(jù)的時(shí)候,可以利用SQL中的GROUP BY語句對數(shù)據(jù)進(jìn)行分組,但是有時(shí)候出于對性能的考慮,不會使用GROUP BY,而是先把數(shù)據(jù)撈出來后,使用代碼,在內(nèi)存中按照某個(gè)屬性進(jìn)行分組。

代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
public class SkuVo {
 
  private Long skuId;
  private String productName;
  private Long brandStoreSn;
 
  public SkuVo(Long skuId, String productName, Long brandStoreSn) {
    super();
    this.skuId = skuId;
    this.productName = productName;
    this.brandStoreSn = brandStoreSn;
  }
 
  public Long getSkuId() {
    return skuId;
  }
  public void setSkuId(Long skuId) {
    this.skuId = skuId;
  }
  public String getProductName() {
    return productName;
  }
  public void setProductName(String productName) {
    this.productName = productName;
  }
  public Long getBrandStoreSn() {
    return brandStoreSn;
  }
  public void setBrandStoreSn(Long brandStoreSn) {
    this.brandStoreSn = brandStoreSn;
  }
 
  @Override
  public String toString() {
    return "SkuVo [skuId=" + skuId + ", productName=" + productName + ", brandStoreSn=" + brandStoreSn + "]";
  }
}

假設(shè)從數(shù)據(jù)查詢出一批數(shù)據(jù),存在了List<SkuVo> 里面了。使用一個(gè)算法按照skuIdList<SkuVo>進(jìn)行分組,skuId相同的歸為一組.

分組算法

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
public class TestArrayListGroupByKey {
 
  public static void main(String[] args) {
    /*1、準(zhǔn)備數(shù)據(jù)**/
    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());
      /*如果取不到數(shù)據(jù),那么直接new一個(gè)空的ArrayList**/
      if (tempList == null) {
        tempList = new ArrayList<>();
        tempList.add(skuVo);
        skuIdMap.put(skuVo.getSkuId(), tempList);
      }
      else {
        /*某個(gè)sku之前已經(jīng)存放過了,則直接追加數(shù)據(jù)到原來的List里**/
        tempList.add(skuVo);
      }
    }
 
    /*3、遍歷map,驗(yàn)證結(jié)果**/
    for(Long skuId : skuIdMap.keySet()){
      System.out.println(skuIdMap.get(skuId));
    }
  }
}

結(jié)果如下

?
1
2
3
4
[SkuVo [skuId=1, productName=p1, brandStoreSn=100]]
[SkuVo [skuId=2, productName=p2, brandStoreSn=101], SkuVo [skuId=2, productName=p5, brandStoreSn=100]]
[SkuVo [skuId=3, productName=p3, brandStoreSn=102], SkuVo [skuId=3, productName=p4, brandStoreSn=103]]
[SkuVo [skuId=5, productName=p6, brandStoreSn=100]]

從輸出結(jié)果看,數(shù)據(jù)已經(jīng)按照skuId進(jìn)行分組了。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

原文鏈接:http://blog.csdn.net/linsongbin1/article/details/54341078

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日本阿v精品视频在线观看 日本xxx片免费高清在线 | 美女18隐私羞羞视频网站 | 公园暴露娇妻小说 | 亚洲精品二三区伊人久久 | 亚洲精品国产综合久久一线 | 久草在线福利视频在线播放 | 91精品国产色综合久久不卡蜜 | 91探花在线观看 | 91寡妇天天综合久久影院 | 农村妇女野战bbxxx农村妇女 | 性欧美高清强烈性视频 | 国产精品午夜性视频网站 | 亚洲精品免费在线 | 午夜影院费试看黄 | 精品国产无限资源免费观看 | 青青草国产免费国产是公开 | 忘忧草在线社区WWW日本直播 | 4tube高清性欧美 | 久久青青草原精品国产软件 | brazzers欧美教师 | 国产高清路线一路线二2022 | 国产福利自产拍在线观看 | japanese乱子mate| 国产91精品露脸国语对白 | 春色视频网站 | 久久伊人中文字幕有码 | 国产久热香蕉在线观看 | 国产精品欧美在线观看 | www.99精品视频在线播放 | 国产麻豆在线观看网站 | 精品国产欧美一区二区三区成人 | 免费一区二区 | 黑人又大又硬又粗再深一点 | 国产精品久久久久久久久久久久 | 日本人交换乱理伦片 | 精品国产一区二区 | 97综合 | 国产区一二三四区2021 | 精品综合久久久久久8888 | 手机看片国产自拍 | 91免费在线播放 |