java ArrayList按照同一属性进行分组

前言:
通常使用SQL查询一批数据的时候,可以利用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());
/*如果取不到数据,那么直接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));
}
}
}
结果如下
[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进行分组了。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# java
# ArrayList按照同一属性进行分组
# ArrayList分组
# ArrayList属性分组
# JAVA ArrayList详细介绍(示例)
# Java中ArrayList类的使用方法
# java的arraylist排序示例(arraylist用法)
# Java ArrayList 数组之间相互转换
# Java中ArrayList的removeAll方法详解
# java ArrayList集合中的某个对象属性进行排序的实现代码
# Java针对ArrayList自定义排序的2种实现方法
# Java中Arraylist动态扩容方法详解
# java 对ArrayList进行分页实例代码
# 你真的理解Java中的ArrayList吗
# 过了
# 遍历
# 希望能
# 谢谢大家
# 先把
# 可以利用
# 捞出
# 数据查询
# setProductName
# setBrandStoreSn
# getBrandStoreSn
# setSkuId
# return
# void
# getSkuId
# getProductName
# color
# List
# ff
# toString
相关文章:
制作公司内部网站有哪些,内网如何建网站?
定制建站平台哪家好?企业官网搭建与快速建站方案推荐
如何快速搭建高效服务器建站系统?
北京网站制作网页,网站升级改版需要多久?
潮流网站制作头像软件下载,适合母子的网名有哪些?
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
如何在IIS管理器中快速创建并配置网站?
建站主机无法访问?如何排查域名与服务器问题
如何注册花生壳免费域名并搭建个人网站?
如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南
如何通过建站之星自助学习解决操作问题?
如何在阿里云服务器自主搭建网站?
宁波免费建站如何选择可靠模板与平台?
无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?
网页制作模板网站推荐,网页设计海报之类的素材哪里好?
临沂网站制作公司有哪些,临沂第四中学官网?
香港服务器租用每月最低只需15元?
免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?
建站主机选虚拟主机还是云服务器更好?
如何确保西部建站助手FTP传输的安全性?
css网站制作参考文献有哪些,易聊怎么注册?
如何设计高效校园网站?
建站之星如何快速解决建站难题?
制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?
建站之星后台管理:高效配置与模板优化提升用户体验
非常酷的网站设计制作软件,酷培ai教育官方网站?
网站制作大概要多少钱一个,做一个平台网站大概多少钱?
北京网站制作公司哪家好一点,北京租房网站有哪些?
网站设计制作公司地址,网站建设比较好的公司都有哪些?
网站插件制作软件免费下载,网页视频怎么下到本地插件?
如何基于云服务器快速搭建网站及云盘系统?
如何在七牛云存储上搭建网站并设置自定义域名?
Python文件管理规范_工程实践说明【指导】
婚礼视频制作网站,学习*后期制作的网站有哪些?
定制建站方案优化指南:企业官网开发与建站费用解析
江苏网站制作公司有哪些,江苏书法考级官方网站?
如何通过万网虚拟主机快速搭建网站?
如何通过服务器快速搭建网站?完整步骤解析
图册素材网站设计制作软件,图册的导出方式有几种?
Thinkphp 中 distinct 的用法解析
商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
建站VPS推荐:2025年高性能服务器配置指南
制作网页的网站有哪些,电脑上怎么做网页?
如何用虚拟主机快速搭建网站?详细步骤解析
如何自定义建站之星网站的导航菜单样式?
北京制作网站的公司,北京铁路集团官方网站?
c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】
宿州网站制作公司兴策,安徽省低保查询网站?
详解jQuery停止动画——stop()方法的使用
*请认真填写需求信息,我们会在24小时内与您取得联系。