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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java怎么像sql的where条件那样处理list里面的数据?相关的知识,希望对你有一定的参考价值。

比如一个sql select * from t where t.name='张三' and age=20 and status=1 and city='杭州' and ...
他的where 条件不固定。
现在有这么一个list里面的数据都是t表, 怎么用java取出数据?因为我不确定哪些查询条件是会有的?

public static void main(String[] args)
vo vo1 = new vo("张三",12,"武汉");
vo vo2 = new vo("李四",12,"武汉");
vo vo3 = new vo("王五",12,"北京");
List<vo> 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);
);


参考技术A 最好是在数据库里查好了,再返回数据,不然数据太多吃内存!追问

不考虑内存,只考虑实现

参考技术B 可以使用在java中使用StringBuffer来动态拼接。 参考技术C 你数据在数据库,为什么不用数据库来查,非要先整内存里再查。少量数据倒是可以随便玩,数据多了服务器不卡死才怪。追问

不考虑内存,只考虑实现

追答

实现就是没有,查内存里边的只有自己写代码逐条比对。

参考技术D bgfeecvftgr

以上是关于java怎么像sql的where条件那样处理list里面的数据?的主要内容,如果未能解决你的问题,请参考以下文章

solr怎么做到像sql中where 1=1

SQL语句 select from where中可否嵌入if条件语句?

es 条件查询能像数据库那样灵活吗?

sql where条件不等于空怎么写

sql中where 之后怎么加if条件判断

在sql的where条件下怎么加判断语句?