自己写的,模仿了SQL的group by分组

本文介绍了一种在Java客户端实现数据分组的方法,避免了客户端进行数据库查询,通过简单的逻辑实现了按特定字段进行分组并统计数据量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在一次的项目上,为了避免客户端进行数据库查询,而且客户端操作的这些数据量也不太多。所以就想直接在客户端用Java实现group by的形式;

public List groupByList(final List<XxxObject> List) {
		if(CollectionUtils.isEmpty(listformdetail)){
			return ;
		}
		List groupbyList = new ArrayList();
		Map<String, Integer> map = new HashMap<String, Integer>();
		
		for (XxxObject obj : List) {
			if (obj.getXxx() != null
					&& obj.getXxx().getXyy() != null) {
				Xyy xyy = obj.getXxx().getXyy();
				//org.apache.commons.lang.StringUtils
				// key值的构成:Xxx编码:Xxx名称,以这两个来进行分组,统计
				String key = StringUtils.trimToEmpty(xyy.getCode()) + ":"
						+ StringUtils.trimToEmpty(xyy.getName());
				if (map.containsKey(key)) {
					Integer val = obj.getAmount().intValue() + map.get(key).intValue();
					map.put(key, val);
				} else {
					map.put(key, obj.getAmount().intValue());
				}
			}
		}

		for (Map.Entry<String, Integer> entry : map.entrySet()) {
			String[] names = StringUtils.splitByWholeSeparator(entry.getKey(), ":");
			Xyy rc = new Xyy();
			XxxDTO dto = new XxxDTO();
			rc.setCode(names[0]);
			rc.setName(names[1]);
			dto.setXyy(rc);
			dto.setAmount(Double.valueOf(entry.getValue()));
			groupbyList.add(dto);
		}
		return groupbyList;
	}

 做一下标识,避免老了,记不住这些小技巧

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值