《苍穹外卖》项目学习记录-Day11订单统计

embedded/2025/2/5 23:41:10/

根据起始时间和结束时间,先把begin放入集合中用while循环当begin不等于end的时候,让begin加一天,这样就把这个区间内的时间放到List集合。

查询每天的订单总数也就是查询的时间段是大于当天的开始时间(0点0分0秒)小于当天的结束时间的(23点59分59秒)的。

//查询每天的订单总数 select count(id) from orders where order_time > ? and order_time < ?

查询有效订单数,不仅是当天的时间段还要状态是已完成的订单,status=5代表已完成。

//查询每天的有效订单数 select count(id) from orders where order_time > ? and order_time < ? and status = 5

/*** 统计指定时间区间内的订单数据* @param begin* @param end* @return*/public OrderReportVO getOrderStatistics(LocalDate begin, LocalDate end) {//存放从begin到end之间的每天对应的日期List<LocalDate> dateList = new ArrayList<>();dateList.add(begin);while (!begin.equals(end)){begin = begin.plusDays(1);dateList.add(begin);}//存放每天的订单总数List<Integer> orderCountList = new ArrayList<>();//存放每天的有效订单数List<Integer> validOrderCountList = new ArrayList<>();//遍历dateList集合,查询每天的有效订单数和订单总数for (LocalDate date : dateList) {//查询每天的订单总数 select count(id) from orders where order_time > ? and order_time < ?LocalDateTime beginTime = LocalDateTime.of(date, LocalTime.MIN);LocalDateTime endTime = LocalDateTime.of(date, LocalTime.MAX);Integer orderCount = getOrderCount(beginTime, endTime,null);//查询每天的有效订单数 select count(id) from orders where order_time > ? and order_time < ? and status = 5Integer validOrderCount = getOrderCount(beginTime, endTime, Orders.COMPLETED);orderCountList.add(orderCount);validOrderCountList.add(validOrderCount);}//计算时间区间内的订单总数量Integer totalOrderCount = orderCountList.stream().reduce(Integer::sum).get();//计算时间区间内的有效订单数量Integer validOrderCount = validOrderCountList.stream().reduce(Integer::sum).get();Double orderCompletionRate = 0.0;if (totalOrderCount != 0){//计算订单完成率orderCompletionRate = validOrderCount.doubleValue() / totalOrderCount;}return OrderReportVO.builder().dateList(StringUtils.join(dateList,",")).orderCountList(StringUtils.join(orderCountList,",")).validOrderCountList(StringUtils.join(validOrderCountList,",")).totalOrderCount(totalOrderCount).validOrderCount(validOrderCount).orderCompletionRate(orderCompletionRate).build();}private Integer getOrderCount(LocalDateTime begin,LocalDateTime end,Integer status){Map map = new HashMap();map.put("begin",begin);map.put("end",end);map.put("status",status);return orderMapper.countByMap(map);}

 ·功能测试

Stream流的使用步骤

1.获取Stream流?

·获取集合的Stream流

Collection提供的如下方法         说明

default Stream<E> stream()      获取当前集合对象的Stream流

·获取数组的Stream流

Arrays类提供的如下方法            说明

public static <T> Stream<T> stream(T[] array)  获取当前数组的Stream流

public static <T> Stream<T> of(T...values)         获取当前接收数据的Stream流

中间方法指的是调用完成后会返回新的Stream流,可以继续使用(支持链式编程)。

终结方法指的是调用完成后,不会返回新的Stream了,没法继续使用流了。

2.Stream提供的常用中间方法     说明

Stream <T> filter(Predicate<? super T>predicate)    用于对流中的数据进行过滤

Stream <T> sorted()                                                  对元素进行升序排序

Stream <T> sorted(Comparator<? super T> comparator) 按照指定规则排序

Stream <T> limit(long maxSize)                                 获取前几个元素

Stream <T> skip(long n)                                             跳过前几个元素

Stream <T> distinct()                                                  去除流中重复的元素

<R>Stream<R> map(Function<? super T,?extends R> mapper)

对元素进行加工,并返回对应的新流

static <T> Stream<T> concat(Stream a,Stream b)     合并a和b两个流为一个流

3.Stream流常见的终结方法

Stream提供的常用终结方法               说明

void forEach(Consumer action)          对此流运算后的元素执行遍历

long count()                                         统计此流运算后的元素个数

Optional<T> max(Comparator<? super T> comparator)

获取此流运算后最大值元素

Optional<T> min(Comparator<? super T> comparator)

获取此流运算后最小值元素

收集Stream流:就是把Stream流操作后的结果转回到集合或者数组中去返回。

Stream流:方便操作集合/数组手段;集合/数组:才是开发中的目的。

Stream提供的常用终结方法                说明

R collect(Collector collector)                把流处理后的结果收集到一个指定的集合中去

Object toArray()                                   把流处理后的结果收集到一个数组中去

流只能收集一次

Collectors工具类提供了具体的收集方式             说明

public static <T> Collector toList()                       把元素收集到List集合中去

public static <T> Collector toSet()                       把元素收集到Set集合中去

public static Collector toMap(Function KeyMapper,Function valueMapper)

把元素收集到Map集合中

我的笔记中没有这个Stream.reduce()方法,所以我去查了一下。

Stream.reduce()是Java 8引入的一个强大的工具,用于对流中的元素进行归纳操作。

reduce方法可以将流中的多个元素组合成一个单一的结果,通常用于求和、求乘积、查找最大值或最小值等操作。

reduce方法的基本用法

reduce(BinaryOperator<T> accumulator)

这种方法没有初始值,流的第一个元素将作为初始值。返回的是Optional<T>,以防流为空。例如:

Optional<Integer> sum = list.stream().reduce((a,b)->a + b);

2.有初始值‌:T reduce(T identity, BinaryOperator<T> accumulator)。这种方法有一个初始值identity,可以保证即使流为空也会有一个默认结果。返回的是T。例如:
int sum = list.stream().reduce(0, (a, b) -> a + b);
‌3.并行流操作‌:reduce(U identity, BiFunction<U, T, U> accumulator, BinaryOperator<U> combiner)。这种方法适用于并行流操作,可以通过两个函数实现累加器和合并器的分离。例如:
int sum = list.parallelStream().reduce(0, (partialResult, element) -> partialResult + element, Integer::sum);
reduce方法的应用场景
‌1.求和‌:将流中的所有元素相加。例如,计算一个整数列表的总和。
‌2.求乘积‌:将流中的所有元素相乘。例如,计算一个整数列表的乘积。
‌3.查找最大值或最小值‌:通过比较操作,找到流中的最大值或最小值。
‌4.连接字符串‌:将流中的字符串元素连接成一个新的字符串。例如,将多个单词连接成一个句子。
‌5.自定义聚合操作‌:通过自定义的累加器函数,实现更复杂的聚合操作。例如,计算两个数的平均值。


http://www.ppmy.cn/embedded/159875.html

相关文章

深入探索SQL中修改表字段属性的技巧与策略

摘要 在SQL中&#xff0c;修改表字段属性是一项常见的数据库管理任务。用户可以调整字段的数据类型、长度、默认值或注释&#xff0c;而无需更改字段名称。例如&#xff0c;varchar类型可转换为mediumtext或text&#xff0c;NVARCHAR2类型可转换为NCLOB。若需同时变更字段名称及…

Spring Boot 日志:项目的“行车记录仪”

一、什么是Spring Boot日志 &#xff08;一&#xff09;日志引入 在正式介绍日志之前&#xff0c;我们先来看看上篇文章中&#xff08;Spring Boot 配置文件&#xff09;中的验证码功能的一个代码片段&#xff1a; 这是一段校验用户输入的验证码是否正确的后端代码&#xff0c…

Reqable:现代化 API 调试工具

Reqable&#xff1a;现代化 API 调试工具 Reqable 是一款专为开发者设计的现代化 API 调试工具&#xff0c;旨在简化 API 开发、测试和调试的流程。 它支持多种协议&#xff08;如 HTTP、HTTPS、WebSocket 等&#xff09;&#xff0c;并提供了丰富的功能&#xff0c;帮助开发…

Windows电脑本地部署运行DeepSeek R1大模型(基于Ollama和Chatbox)

文章目录 一、环境准备二、安装Ollama2.1 访问Ollama官方网站2.2 下载适用于Windows的安装包2.3 安装Ollama安装包2.4 指定Ollama安装目录2.5 指定Ollama的大模型的存储目录 三、选择DeepSeek R1模型四、下载并运行DeepSeek R1模型五、常见问题解答六、使用Chatbox进行交互6.1 …

蓝桥杯三国游戏(贪心)

贪心&#xff1a;不是从整体上考虑最优解&#xff0c;而是从局部考虑&#xff0c;类似dp贪心的决策是需要有无后效性的&#xff0c;且局部最优解可以推到整体最优 3 1 2 2 2 3 2 1 0 7 2分析&#xff1a; 本题的意思是选择几个事件&#xff08;可不连续&#xff09;&#xff…

蓝桥杯模拟算法:蛇形方阵

P5731 【深基5.习6】蛇形方阵 - 洛谷 | 计算机科学教育新生态 我们只要定义两个方向向量数组&#xff0c;这种问题就可以迎刃而解了 比如我们是4的话&#xff0c;我们从左向右开始存&#xff0c;1&#xff0c;2&#xff0c;3&#xff0c;4 到5的时候y就大于4了就是越界了&…

RESTful 架构原则及其在 API 设计中的应用

RESTful 架构原则及其在 API 设计中的应用 RESTful 架构原则及其在 API 设计中的应用第一章&#xff1a;REST 基础概念1.1 什么是 REST&#xff1f;1.2 RESTful 架构的特点 第二章&#xff1a;RESTful 架构的核心原则2.1 资源(Resources)2.2 统一接口(Uniform Interface)2.3 状…

中继器与集线器

一、中继器&#xff08;Repeater&#xff09; 1. 定义与功能 定位&#xff1a;OSI模型的物理层设备。 核心功能&#xff1a;放大和再生信号&#xff0c;解决信号在传输过程中的衰减问题。 信号在传输介质&#xff08;如双绞线、光纤&#xff09;中会因距离增加而衰减&#xf…