Apache Echarts
data:image/s3,"s3://crabby-images/57983/579838a052325de029726224c7dcfa98faa24c4d" alt=""
data:image/s3,"s3://crabby-images/35ff6/35ff6ab847a362bf5256f3bcc5e6ac4826ec38fc" alt=""
data:image/s3,"s3://crabby-images/fd696/fd6967662c7e5ae735ab7598c52d1683ee6329ae" alt=""
data:image/s3,"s3://crabby-images/fd3d0/fd3d0079bf76100d41161c256dc2fc97bc5dfcb9" alt=""
data:image/s3,"s3://crabby-images/8f0df/8f0df174dbfc1fe5cd37ccc0f7b2fe4913e5ea85" alt=""
data:image/s3,"s3://crabby-images/b1bee/b1beed3d87ce78f3c34452b53512e3cf844e1fd7" alt=""
营业额统计
data:image/s3,"s3://crabby-images/aa7d5/aa7d529542335244c62912f06602b90622e003e2" alt=""
重点:已完成订单金额要排除其他状态的金额 根据时间选择区间
data:image/s3,"s3://crabby-images/dca2d/dca2d1e69d8df0636b3d958fc3458d1703360e9f" alt=""
设计vo用于后端向前端传输数据,dto用于后端接收前端发送的数据
java
@GetMapping("/turnoverStatistics")
@ApiOperation("营业额统计")
public Result<TurnoverReportVO> turnoverStatistics(
@DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate begin,
@DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate end){
log.info("营业额数据统计:{},{}",begin,end);
return Result.success(reportService.getTurnoverStatistics(begin,end));
}
java
public TurnoverReportVO getTurnoverStatistics(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<Double> 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 > beginTime and order_time < endTime and status = 5
Map map = new HashMap();
map.put("begin", beginTime);
map.put("end", 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();
}