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

服務(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í)候出于對性能的考慮,不會(huì)使用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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 95视频在线观看在线分类h片 | 女教师系列三上悠亚在线观看 | 国产美女久久久久 | 99精品国产成人一区二区在线 | 亚洲国产精品成人久久 | 明星ai人脸替换造梦在线播放 | 国产免费好大好硬视频 | 波多野结衣两女调教 | 青草视频久久 | 猫咪色网 | 亚州成人 | 狠狠色综合久久久久尤物 | 亚洲国产成人99精品激情在线 | 亚洲一卡2卡三卡4卡5卡组 | 国产欧美日韩精品一区二 | 99热视| 精品久久久久久久久免费影院 | 非洲一级毛片又粗又长aaaa | 果冻传媒和91制片厂网站软件 | 3d动漫美女被吸乳羞羞有 | 欧美特黄特色aaa大片免费看 | 二区三区在线观看 | 国产精品麻豆99久久 | 97影音 | 国产农村一级特黄α真人毛片 | yy8090韩国日本三理论免费 | 免费视频一区 | 亚洲国产成人久久综合一区 | 男人都懂www深夜免费网站 | 欧美国产在线视频 | www.成人在线视频 | 精品日韩欧美一区二区三区 | 青青青手机在线观看 | 日韩一级精品视频在线观看 | 操国产美女 | 亚洲国产情侣一区二区三区 | 狠狠干2016 | 99这里只有精品视频 | 日韩在线观看网址 | 无限时间看片在线观看 | free哆拍拍免费永久视频 |