java怎么像sql的where条件那样处理list里面的数据?

2025-01-20 23:51:24
推荐回答(5个)
回答1:

public static void main(String[] args){
vo vo1 = new vo("张三",12,"武汉");
vo vo2 = new vo("李四",12,"武汉");
vo vo3 = new vo("王五",12,"北京");
List list = Arrays.asList(vo1,vo2,vo3);

//条件
vo vo4 = new vo("",null,"武汉");

if(vo4.getName() != null && !"".equals(vo4.getName())){
list = list.stream().filter(vo -> vo.getName().equals(vo4.getName()))
.collect(Collectors.toList());
}
if(vo4.getAge() != null){
list = list.stream().filter(vo -> vo.getAge().equals(vo4.getAge()))
.collect(Collectors.toList());
}
if(vo4.getCity() != null && !"".equals(vo4.getCity())){
list = list.stream().filter(vo -> vo.getCity().equals(vo4.getCity()))
.collect(Collectors.toList());
}

list.stream().forEach(vo -> {
System.out.println(vo);
});
}


回答2:

最好是在数据库里查好了,再返回数据,不然数据太多吃内存!

回答3:

可以使用在java中使用StringBuffer来动态拼接。

回答4:

你数据在数据库,为什么不用数据库来查,非要先整内存里再查。少量数据倒是可以随便玩,数据多了服务器不卡死才怪。

回答5:

bgfeecvftgr