当前位置: 首页 > article >正文

【烘焙坊项目】后端搭建(13)- 数据统计--图形报表

一、Apache ECharts1.1介绍Apache ECharts是一款基于Javascript的数据可视化图表库提供直观生动可交互可个性化定制的数据可视化图表。官网地址Apache ECharts总结使用Echarts重点在于研究当前图表所需的数据格式。通常是需要后端提供符合格式要求的动态数据然后响应给前端来展示图表。二、营业额统计2.1需求分析和设计业务规则营业额指订单状态为已完成的订单金额合计基于可视化报表的折线图展示营业额数据x轴为日期y轴为营业额根据时间选择区间展示每天的营业额数据查看接口文档2.2代码开发controller层service层Service Slf4j public class ReportServiceImpl implements ReportService { Autowired private OrderMapper orderMapper; /** * 统计指定时间区间内的营业额数据 * param begin * param end * return */ Override public TurnoverReportVO getTurnoverReport(LocalDate begin, LocalDate end) { //当前集合用于存放从begin到end范围内的每天日期 ListLocalDate dateList new ArrayList(); dateList.add(begin); while(!begin.equals(end)){ //日期计算计算指定日期的后一天对应的日期 begin begin.plusDays(1); dateList.add(begin); } //存放每天的营业额 ListDouble turnoverList new ArrayList(); for(LocalDate date:dateList){ //查询date日期对应的营业额,营业额是指状态为“已完成”的订单金额合计 LocalDateTime beginTime LocalDateTime.of(date, LocalTime.MIN); LocalDateTime endTime LocalDateTime.of(date, LocalTime.MAX); //select sum(amount) from orders where order_time ? and order_time ? and status 5 Map map new HashMap(); map.put(beginTime,beginTime); map.put(endTime,endTime); map.put(status, Orders.COMPLETED); Double turnover orderMapper.sumByMap(map); turnover turnover null ? 0.0 : turnover; turnoverList.add(turnover); } //封装返回结果 return TurnoverReportVO .builder() .dateList(StringUtils.join(dateList, ,))//用“,”分隔开 .turnoverList(StringUtils.join(turnoverList, ,)) .build(); } }dao层2.3功能测试通过三、用户统计3.1需求分析和设计业务规则基于可视化报表的折线图展示用户数据x轴为日期y轴为用户数根据时间选择区间展示每天的用户总量和新增用户量数据查看接口文档3.2代码开发controller层service层/** * 统计指定时间内的新增用户和总用户数据 * param begin * param end * return */ Override public UserReportVO getUserReport(LocalDate begin, LocalDate end) { //存放从begin到end之间每天对应的日期 ListLocalDate dateList new ArrayList(); dateList.add(begin); while(!begin.equals(end)){ begin begin.plusDays(1); dateList.add(begin); } //存放每天的新增用户数量 ListInteger newUserList new ArrayList(); //存放每天总用户数量 ListInteger totalUserList new ArrayList(); for (LocalDate date : dateList) { LocalDateTime beginTime LocalDateTime.of(date, LocalTime.MIN); LocalDateTime endTime LocalDateTime.of(date, LocalTime.MAX); Map map new HashMap(); map.put(endTime,endTime); Integer totalUser userMapper.countByMap(map);//总用户数量 totalUserList.add(totalUser); map.put(beginTime, beginTime); Integer newUser userMapper.countByMap(map);//新增用户数量 newUserList.add(newUser); } return UserReportVO .builder() .dateList(StringUtils.join(dateList, ,)) .newUserList(StringUtils.join(newUserList, ,)) .totalUserList(StringUtils.join(totalUserList, ,)) .build(); }dao层3.3功能测试通过四、订单统计4.1需求分析和设计业务规则有效订单指状态为“已完成”的订单基于可视化报表的折线图展示订单数据x轴为日期y轴为订单数量根据时间选择区间展示每天的订单总数和有效订单数展示所选时间区间内的有效订单数、总订单数、订单完成率、订单完成率有效订单数/总订单数*100%查看接口文档4.2代码开发controller层service层/** * 统计指定时间内的订单相关数据 * param begin * param end * return */ Override public OrderReportVO getStatisticsReport(LocalDate begin, LocalDate end) { //存放从begin到end之间每天对应的日期 ListLocalDate dateList new ArrayList(); dateList.add(begin); while(!begin.equals(end)){ begin begin.plusDays(1); dateList.add(begin); } //存放每天的订单数量列表 ListInteger orderCountList new ArrayList(); //存放每天有效订单数量列表 ListInteger validOrderCountList new ArrayList(); //存放订单总数 Integer totalOrderCount 0; //存放有效订单总数 Integer validOrderCount 0; //存放订单完成率 Double orderCompletionRate 0.0; for (LocalDate date : dateList) { LocalDateTime beginTime LocalDateTime.of(date, LocalTime.MIN); LocalDateTime endTime LocalDateTime.of(date, LocalTime.MAX); Map map new HashMap(); map.put(beginTime,beginTime); map.put(endTime,endTime); Integer totalOrder orderMapper.countOrderByMap(map);//每日订单数量 orderCountList.add(totalOrder); if(totalOrder!null){ totalOrderCount totalOrderCount totalOrder; } map.put(status, Orders.COMPLETED); Integer validOrder orderMapper.countOrderByMap(map);//每日有效订单数 validOrderCountList.add(validOrder); if(validOrder!null){ validOrderCount validOrderCount validOrder; } } orderCompletionRate totalOrderCount0 ? 0.0 :(validOrderCount*1.0/totalOrderCount); return OrderReportVO .builder() .dateList(StringUtils.join(dateList, ,)) .orderCountList(StringUtils.join(orderCountList,,)) .validOrderCountList(StringUtils.join(validOrderCountList,,)) .orderCompletionRate(orderCompletionRate) .totalOrderCount(totalOrderCount) .validOrderCount(validOrderCount) .build(); }dao层4.3功能测试通过五、销量排名Top105.1需求分析和设计业务规则根据时间选择区间展示销量前十的商品包括菜品和套餐基于可视化报表的柱状图降序展示商品销量此处的销量为商品销售的份数查看接口文档5.2代码开发controller层service层dao层5.3功能测试通过六、小结注意MySql语句中 select sum()...是统计具体的数值总和select count()...是统计符合记录数有几条请勿混淆订单统计部分业务代码还是有些复杂的没有跟着老师走看看接口文档自己设计也能够顺畅运行。销量排名部分的sql语句有一些长考虑的较多。

相关文章:

【烘焙坊项目】后端搭建(13)- 数据统计--图形报表

一、Apache ECharts 1.1介绍 Apache ECharts是一款基于Javascript的数据可视化图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表。 官网地址:Apache ECharts 总结:使用Echarts,重…...

高效运维新选择:Shell 脚本自动化生成可视化 Linux 系统健康报告

1. 为什么需要自动化系统健康报告? 每次登录服务器手动检查系统状态的日子该结束了。想象一下,你管理着几十台Linux服务器,每天要重复执行相同的命令查看CPU、内存、磁盘使用情况,这种重复劳动不仅效率低下,还容易遗漏…...

SpringAI + Manus实战:AI Agent开发中的常见坑与优化技巧

SpringAI Manus实战:AI Agent开发中的常见坑与优化技巧 在AI Agent开发领域,技术选型和框架使用往往决定了项目的成败。SpringAI和Manus作为当前热门的开发框架,为开发者提供了强大的工具链,但在实际应用中仍存在诸多挑战。本文将…...

别再踩坑了!Vue中使用postMessage传值的5个注意事项(含window.opener最佳实践)

Vue项目中postMessage通信的深度实践指南 跨窗口通信一直是前端开发中的难点,尤其在Vue这类现代框架中,如何安全高效地使用postMessage进行数据传递,是每个开发者都需要掌握的技能。本文将深入探讨postMessage在Vue项目中的实际应用场景&…...

鸿蒙HarmonyOS无线调试全攻略:摆脱USB线束缚的5个关键步骤

鸿蒙无线调试实战指南:彻底告别数据线的5个高阶技巧 作为一名长期在咖啡厅、机场甚至地铁上写代码的鸿蒙开发者,我深刻理解被数据线束缚的痛苦。直到发现HarmonyOS原生的无线调试方案,才真正体会到"剪断最后一根线"的自由感。本文将…...

彻底搞懂 Java 垃圾回收(GC)

在 Java 后端开发、面试、线上性能优化、OOM 排查中,GC(垃圾回收) 都是绕不开的核心基石。很多人只知道 GC 是自动回收内存,但到底怎么回收、什么时候回收、为什么会卡顿、不同回收器区别是什么,一知半解。这篇文章我用…...

基于混沌-高斯变异-麻雀搜索算法(CGSSA)优化BP神经网络(CGSSA-BP)的回归预测M...

基于混沌-高斯变异-麻雀搜索算法(CGSSA)优化BP神经网络(CGSSA-BP)的回归预测(含优化前后对比)MATLAB代码 代码注释清楚。 main为主程序,可以读取EXCEL数据。 很方便,容易上手。 &a…...

从ADB连接到权限修改:深入解析安卓APK安装的底层步骤

1. ADB连接:从物理连接到权限握手 很多人以为安卓APK安装就是双击文件那么简单,但当你需要调试系统级应用或修改预装应用时,就会发现事情没那么简单。我去年给某厂商定制系统应用时,光是为了让调试环境跑通就折腾了整整两天。下面…...

永磁同步电机PMSM的5+7次谐波注入与死区补偿策略:降低转矩脉动及电压补偿详解,附PPT、文...

永磁同步电机PMSM电机57次谐波注入,可以有效降低转矩脉动。 死区补偿后,有效降低转矩脉动。 电压补偿。 有ppt说明,文章和相应simulink模型。 描述真实,已更新,现在有两套模型。最近在调试永磁同步电机时发现个有意思的…...

探索多智能体系统中的事件触发控制代码

事件触发控制代码,每个代码有对应参考文献 1.多智能体中基于事件触发的协议 2.多智能体分布式系统的事件触发控制 3.基于观测器的非理想线性多智能体事件触发的跟踪一致性 4.非线性不确定扰动多智能体系统固定时间事件触发一致性控制 5.固定拓扑和切换多智能体分布式…...

短视频创作者的福音:Qwen3-ForcedAligner-0.6B毫秒级对齐,字幕制作效率翻倍

短视频创作者的福音:Qwen3-ForcedAligner-0.6B毫秒级对齐,字幕制作效率翻倍 1. 为什么短视频创作者需要精准字幕对齐? 在短视频内容爆炸式增长的今天,字幕已经成为提升观看体验的关键要素。数据显示,85%的观众会在静…...

锂电池温度检测Comsol仿真 软包锂电池表面温度变化仿真模拟,不同位置探针测温 #汽车级锂电池

锂电池温度检测Comsol仿真 软包锂电池表面温度变化仿真模拟,不同位置探针测温 #汽车级锂电池 Comsol仿真 最近在折腾汽车锂电池的温控仿真,发现软包电池的表面温度分布真是门玄学——同一个电池组里不同位置的温差能玩出花样。这次用COMSOL搞了个三维模…...

CH579 串口服务器 DTU 项目功能架构与实现解析

CH579 以太网转串口 串口服务器代码! 需要自己编程提升能力的非常值得参考的代码 几乎所有的编程思路编程技巧资源都涉及到了,代码简单易懂 ,注释清楚,本代码实现最串口服务器的功能,有电路图。CH579 串口服务器 DTU&a…...

CogVideoX-2b效果展示:看看这些由文字生成的精美短视频

CogVideoX-2b效果展示:看看这些由文字生成的精美短视频 1. 当文字开始流动:一次全新的视觉叙事体验 想象一下,你写下“一只戴着飞行员护目镜的柯基犬,在夕阳下的金色麦田里快乐奔跑”,然后点击一个按钮。两分钟后&am…...

避坑指南:VS2022中C#语言版本修改的正确姿势(含.NET Core版本查询技巧)

避坑指南:VS2022中C#语言版本修改的正确姿势(含.NET Core版本查询技巧) 当你在Visual Studio 2022中打开一个历史遗留项目时,是否遇到过这样的报错:"Feature xxx is not available in C# 7.3..."&#xff1f…...

西门子200smart PID算法源码探秘

西门子200smart PID算法源码,经过验证没问题 优点: 支持两路pwm输出与模拟量输出,可以用于恒温箱,一路控制加热一路控制制冷。 也可以用于恒压场合,一路控制加压阀一路控制泄压阀。 可以突破Pid向导8路限制最近在研究西门子200sma…...

Ubuntu 22.04 LTS下NVIDIA驱动安装避坑指南:如何用终端一键搞定(附常见错误解决)

Ubuntu 22.04 LTS下NVIDIA驱动安装避坑指南:如何用终端一键搞定(附常见错误解决) 在Linux系统上安装NVIDIA显卡驱动一直是让不少开发者头疼的问题。特别是对于Ubuntu 22.04 LTS用户来说,虽然系统本身对NVIDIA显卡的支持已经相当完…...

Claude Architect认证到底考什么?一个重度用户用半年实战逐项拆解

最近刷到一篇英文爆款:《I want to become a Claude architect (full course)》,756万浏览、5.6万收藏。作者把Anthropic官方的Claude Certified Architect考试大纲拆得底朝天。 我呢?用Claude Code写了整整大半年代码,从预测市场…...

别再死磕FTP了!手把手教你用SFTP连接Ubuntu虚拟机,FileZilla秒连成功

告别FTP连接困境:Ubuntu虚拟机SFTP配置全指南 每次在FileZilla里反复尝试FTP连接却总是失败?看着那些晦涩的错误提示却无从下手?作为开发者,我们经常需要在本地机器和Ubuntu虚拟机之间传输文件,而传统的FTP协议往往会成…...

Dell R730服务器部署Nvidia K80 GPU驱动与深度学习环境全攻略

1. 环境准备:从零开始的硬件与软件检查 在Dell R730服务器上部署Nvidia K80 GPU之前,我们需要像装修房子前检查地基一样做好准备工作。首先确认服务器已经正确安装了K80计算卡——这个双槽位的大家伙需要占用两个PCIe插槽,记得检查供电接口是…...

2026 AI财经落地实录:5个真实案例,告诉你具体怎么做才能见效

最近刷到不少讨论,说2026年AI在金融圈终于要“爆发”了。可我一查海外英文报告,发现好多大机构早就不是在“试水”,而是把AI直接塞进核心流程里,每天都在跑,省钱、省人力,还真金白银地降了风险。 你以为AI…...

U8g2自定义中文字库实战:从零构建Arduino OLED专属字体

1. 为什么需要自定义U8g2中文字库 在嵌入式开发中,我们经常会遇到需要在OLED屏幕上显示中文的需求。使用U8g2库自带的完整中文字库虽然方便,但对于存储空间有限的开发板(如Arduino UNO)来说,这可能会带来严重的问题。 …...

6.4 日志到底怎么写才有用?排障效率提升的底层方法

第6章 第4节:日志到底怎么写才有用?排障效率提升的底层方法 章节主题:安全测试与工程质量 关键词:AI协作、产品交付、工程化、可持续迭代 一、开场:为什么这件事值得你现在就做 很多读者问过同一个问题:日志到底怎么写才有用?排障效率提升的底层方法。 在大量项目复盘…...

05_Priority Queues 优先队列

title: 05_Priority Queues 优先队列 categories: 02_Silver tags: 优先队列堆Priority QueueHeap Priority Queues 优先队列 简介 优先队列(Priority Queue 或 Heap)支持以下操作: 插入元素删除最高优先级元素获取最高优先级元素 以上操…...

等保三级下主流厂商网络设备安全配置实战指南

1. 等保三级网络设备安全配置的核心要求 等保三级作为国内网络安全等级保护的重要标准,对网络设备的安全配置提出了明确要求。在实际项目中,我经常遇到工程师对等保要求理解不到位的情况,导致设备配置反复修改。这里我结合多年经验&#xff0…...

6.3 能跑不等于能交付:测试分层与回归方案

第6章 第3节:能跑不等于能交付:测试分层与回归方案 章节主题:安全测试与工程质量 关键词:AI协作、产品交付、工程化、可持续迭代 一、开场:为什么这件事值得你现在就做 很多读者问过同一个问题:能跑不等于能交付:测试分层与回归方案。 在大量项目复盘中可以看到,真正…...

ComfyUI文生图工作流参数调优实战:从新手到进阶的5个关键技巧

ComfyUI文生图工作流参数调优实战:从新手到进阶的5个关键技巧 当你已经能够用ComfyUI生成基本图像后,是否遇到过这些困扰:明明用了精心设计的提示词,结果却总差强人意?生成的人物面部细节模糊得像打了马赛克&#xff1…...

GenICam GenTL 标准 ver1.5(2)GenTL传输层:连接相机与应用的桥梁

1. GenTL传输层:机器视觉的"数据高速公路" 想象一下你正在建设一个智能工厂,需要把20台不同品牌的工业相机接入同一个检测系统。有的相机用GigE网线传输数据,有的用USB3.0接口,还有的使用Camera Link HS高速接口——这就…...

Avalonia 开发环境配置全攻略:从零搭建到高效开发

1. Avalonia开发环境搭建入门指南 第一次接触Avalonia的开发者可能会被各种配置步骤搞得晕头转向。作为一个跨平台的.NET UI框架,Avalonia确实需要一些前期准备工作才能开始愉快的编码之旅。不过别担心,跟着我的步骤走,保证你能在半小时内搞定…...

手把手教你用DiskGenius给瘦客户机分区(WinPE环境实操指南)

瘦客户机系统部署实战:WinPE环境下DiskGenius分区与系统安装全解析 瘦客户机作为企业级精简计算设备,其系统部署与传统PC存在显著差异。许多IT运维人员在初次接触这类设备时,往往会被其特殊的硬件架构和系统要求所困扰。本文将深入探讨如何在…...