List排序去重

今天有这么一个需求,需要将数据库里面的数据查询出来显示到页面上,但是数据很乱根本就不能通过一个sql与语句写出来,如果是一个sql能写出来的就简单了 直接使用jdbc.queryForList就可以了 但是现实很残酷,还要要求去重和按时间排序

因为hibernate的局限性,项目针对比较复杂的查询都是采用jdbcTemplate查询,所以呢我这里最后将页面显示的list内容是通过拼起来的

//结果集list
List resultList = new ArrayList();

List list1  = jdbc.queryForList(sql,new Object[]{param...});
List List2 = jdbc.queryForList(sql,new Object[]{param...});

resultList.addAll(list1);
resultList.addAll(list2);

//去重
Set tempSet = new HashSet(resultList);
resultList.clear(); //清空resultList 不然会叠加
resultList.addAll(tempSet);

//排序(这里其实List里面存的是Map),这里是按照DECL_DATE倒叙排列,如果要正序就return m1.get("DECL_DATE").toString().compareTo(m2.get("DECL_DATE").toString());就可以了
Collections.sort(newsMainList, new Comparator(){
@Override
public int compare(Object o1, Object o2) {
Map m1 = (Map)o1;
Map m2 = (Map)o2;
return m2.get("DECL_DATE").toString().compareTo(m1.get("DECL_DATE").toString());
}});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值