JAVA8中对List<map<String,Object>>根据map某个value值进行排序,还支持中文排序,可以替代order by

最近在优化系统,其中常见性能瓶颈为group by和order by联合使用,下面使用java来实现order by,以提高SQL性能。

直接上代码:


import com.example.jdk8.java.common.ChineseComparator;

import java.util.*;
import java.util.stream.Collectors;

public class ListMapStreamSort {
    public static void main(String[] args) {
        Map<String, Object> map = new HashMap<String, Object>();
        map.put("name", "高一(1)班");
        map.put("age", 13);

        Map<String, Object> map2 = new HashMap<String, Object>();
        map2.put("name", "高一(11)班");
        map2.put("age", 15);

        Map<String, Object> map3 = new HashMap<String, Object>();
        map3.put("name", "高一(1)班");
        map3.put("age", 20);

        Map<String, Object> map4 = new HashMap<String, Object>();
        map4.put("name", "高一(2)班");
        map4.put("age", 18);

        List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
        list.add(map);
        list.add(map2);
        list.add(map3);
        list.add(map4);
        System.out.println("排序前:"+list);
        List<Map> collect =
                list.stream().sorted((o1, o2) -> ChineseComparator.compareString(o1.get("name")+"",o2.get("name")+""))
                        .collect(Collectors.toList());

        System.out.println("排序后:"+collect);
    }

}

执行结果为:

 ChineseComparator类,请见Java8对中文汉字排序的Comparator实现类_一火的专栏-CSDN博客

  • 4
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
假设有一个list对象,其每个元素都是一个map对象,map包含了多个key-value对。现在的问题是需要对list进行排序排序顺序需要满足多个条件的组合,如何实现呢? 首先需要明确的是,list的每个元素都是map对象,而且map对象valueobject类型,可能是各种类型的数据。因此,在进行多条件排序时,需要考虑到不同类型之间的比较规则。 解决方案如下: 1. 定义一个比较器类,实现Comparator接口,重载其的compare方法。该方法用于两个map对象之间的比较,并根据比较结果返回一个int,用于排序。 2. 在比较器类定义多个成员变量,用于记录排序的多个条件,例如: private String[] orderBy = {"age", "name", "salary"}; // 定义排序的字段 private Boolean[] isAsc = {false, true, true}; // 定义每个字段是否升序排序 3. 在compare方法,逐一比较两个map对象指定的多个字段,并根据isAsc数组记录的排序方式进行排序。例如: for (String field : orderBy) { Object o1 = m1.get(field); Object o2 = m2.get(field); if (o1 == null || o2 == null) { continue; } if (o1 instanceof Integer) { Integer i1 = (Integer) o1; Integer i2 = (Integer) o2; int compare = i1.compareTo(i2); if (compare != 0) { return isAsc[index] ? compare : -compare; } } else if (o1 instanceof String) { String s1 = (String) o1; String s2 = (String) o2; int compare = s1.compareTo(s2); if (compare != 0) { return isAsc[index] ? compare : -compare; } } // other types } 4. 在使用Collections.sort方法对list进行排序时,指定比较器类即可。例如: Collections.sort(list, new MyComparator()); 通过上述方案,可以实现listmap对象按指定的多个字段进行排序排序方式可以是升序或降序。对于不同类型的数据,可以分别进行对应的比较规则。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秋9

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值