在一次的项目上,为了避免客户端进行数据库查询,而且客户端操作的这些数据量也不太多。所以就想直接在客户端用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;
}
做一下标识,避免老了,记不住这些小技巧