java list 字段去重复_List中去除某些对象某个字段的重复值

问题描述如下:

有一个List  list 放了五个对象:user1、user2、user3、user4、user5

User有三个属性Id、name、age

其中user2的记录大概是这样:“100”,"abc",20;

user3的记录大概是这样:“100”,“def”,20;

请问怎么才能只保留user2和user3中的一个对象,并将其中的name合并到新对象中,

新对象如“100”,“abcdef”,20

这只是举个例子,实际中有可能user4和user5与此类似,如果有id相同的两个对象,则对其进行

合并,只保留一个对象,求一个通用的方法,能筛选出对象集合中某些相同ID的两个对象,将其合并

仍保留在原list中

importjava.util.ArrayList;

importjava.util.HashMap;

importjava.util.List;

publicclassTestDemo1 {

publicstaticvoidmain(String[] args) {

List list =newArrayList<>();

list.add(newUser(1,"a",20));

list.add(newUser(1,"a",20));

list.add(newUser(2,"a",20));

list.add(newUser(3,"b",20));

list.add(newUser(1,"c",20));

list.add(newUser(4,"d",20));

list.add(newUser(2,"e",20));

list.add(newUser(1,"a",20));

list = mySort(list);

for(User user : list) {

System.out.println(user.toString());

}

}

publicstaticList mySort(List list){

HashMap tempMap =newHashMap<>();

for(User user : list) {

intkey = user.getId();

if(tempMap.containsKey(key)){

User tempUser =newUser(key,tempMap.get(key).getName() + user.getName(),tempMap.get(key).getAge());

tempMap.put(key, tempUser);

}else{

tempMap.put(key, user);

}

}

List tempList =newArrayList<>();

for(intkey : tempMap.keySet()){

tempList.add(tempMap.get(key));

}

returntempList;

}

}

classUser{

privateintid;

privateString name;

privateintage;

publicUser(){}

publicUser(intid, String name,intage) {

super();

this.id = id;

this.name = name;

this.age = age;

}

publicintgetId() {

returnid;

}

publicvoidsetId(intid) {

this.id = id;

}

publicString getName() {

returnname;

}

publicvoidsetName(String name) {

this.name = name;

}

publicintgetAge() {

returnage;

}

publicvoidsetAge(intage) {

this.age = age;

}

@Override

publicString toString() {

return"User [id="+ id +", name="+ name +", age="+ age +"]";

}

}

SQL: SELECT

a1.id,

a1. NAME,

GROUP_CONCAT(a2.type),

a1.click,

a1.hits,

a1.add_time,

a1. STATUS

FROM

advertise a1

LEFT JOIN advertise_show_type a2 ON a1.id = a2.advertise_id

WHERE

a1.del = 0 and a2.del = 0

group by id

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值