1 问题背景
场景是电商查询优惠活动的活动列表,有8种活动。针对搭售类型的活动按照状态正序、优先级倒叙来排序。其余类型的优惠活动按照创建时间倒叙排序。
2 分析
考虑到只有8种活动中只有1种活动需要特殊的排序规则,那么就不在sql处书写控制搭售活动的排序代码,sql处默认使用大部分活动的排序规则——按时间倒叙,而搭售活动的排序在java代码层面控制,笔者使用Java8流技术来处理排序。
3 实现
3.1 单字段排序
按照status正序排序,按照status倒序排序
// 从数据库列表查询
List<DiscountDTO> discountList = discountMapper.listDiscount();
// 按照status正序排序
discountList.stream().sorted(Comparator.comparing(DiscountDTO::getStatus));
// 按照status倒序排序
discountList.stream()
.sorted(Comparator.comparing(DiscountDTO::getStatus, (val1, val2) -> val2 - val1));
3.2 多字段级联排序
按照status正序、sequence倒序
// 按照status正序、sequence倒序
discountList
.stream()
.sorted(Comparator.comparing(DiscountDTO::getStatus).thenComparing(DiscountDTO::getSequence, (val1, val2) -> val2 - val1));