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