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

比如一个sqlselect*fromtwheret.name='张三'andage=20andstatus=1andcity='杭州'and...他的where条件不固定... 比如一个sql select * from t where t.name='张三' and age=20 and status=1 and city='杭州' and ...
他的where 条件不固定。
现在有这么一个list里面的数据都是t表, 怎么用java取出数据?因为我不确定哪些查询条件是会有的?
展开
 我来答
和蔼的曙光007
2018-11-29
知道答主
回答量:1
采纳率:0%
帮助的人:802
展开全部

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);
});
}


linzhi566
2014-12-15 · 超过24用户采纳过TA的回答
知道答主
回答量:89
采纳率:0%
帮助的人:37.6万
展开全部
最好是在数据库里查好了,再返回数据,不然数据太多吃内存!
追问
不考虑内存,只考虑实现
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
逐客教我
2014-12-15
知道答主
回答量:26
采纳率:0%
帮助的人:10.4万
展开全部
可以使用在java中使用StringBuffer来动态拼接。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
路亚向前冲8t
2014-12-15 · TA获得超过484个赞
知道小有建树答主
回答量:636
采纳率:0%
帮助的人:437万
展开全部
你数据在数据库,为什么不用数据库来查,非要先整内存里再查。少量数据倒是可以随便玩,数据多了服务器不卡死才怪。
追问
不考虑内存,只考虑实现
追答
实现就是没有,查内存里边的只有自己写代码逐条比对。
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
伤心无殇
2014-12-15
知道答主
回答量:3
采纳率:0%
帮助的人:3834
展开全部
bgfeecvftgr
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式