English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

javaのArrayListを同じ属性に基づいてグループ化する

javaのArrayListを同じ属性に基づいてグループ化する

前書き:

SQLクエリを使用して一括でデータを取得する場合、GROUP BY文を使用してデータをグループ化することができますが、パフォーマンスの観点からGROUP BYを使用しない場合があります。その場合、データを一括で取得した後、コードでメモリ内で特定の属性に基づいてデータをグループ化します。

コード

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 + "]";
  }
}

データクエリから一括でデータを取得し、それがList<SkuVo>に存在する場合、skuIdに基づいてList<SkuVo>をグループ化するアルゴリズムを使用して、skuIdが同じものを同一グループにまとめます。

分组算法

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());
      /*データが取得できない場合、新しい空のArrayListを作成します**/
      if (tempList == null) {
        tempList = new ArrayList<>();
        tempList.add(skuVo);
        skuIdMap.put(skuVo.getSkuId(), tempList);
      }
      else {
        /*あるskuがすでに保存されている場合、元のリストにデータを追加します**/
        tempList.add(skuVo);
      }
    }
    /*3、マップをループして結果を確認**/
    for(Long skuId : skuIdMap.keySet()){
      System.out.println(skuIdMap.get(skuId));
    }
  }
}

結果は以下の通りです

[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]]

出力結果から見ると、データはskuIdにグループ化されています。

ご読覧ありがとうございます、皆様のサポートに感謝します!

おすすめ