获取时间段内所有的(hour,day,month,year)累加和,数据库没数据的补0

解释看hour代码,其他同理

@Override
public WorkOrderReportVo queryRepair(String startTime, String endTime, String cycle) {
	// sql查出数据
	List<WorkProcessCompleteVo> dataList = new ArrayList<>();

	List<Map<String, Object>> comList = new ArrayList<>();

	WorkOrderReportVo reportVo = new WorkOrderReportVo();// 返回数据

	if (CycleType.HOUR.equals(cycle)) {
	    //已有的时间
		comList = workOrderProcessRepositoryDsl.queryCompleteHour(startTime, endTime);

		//已有的时间
		comList.forEach(m -> {
			WorkProcessCompleteVo compVo = new WorkProcessCompleteVo();
			compVo.setCycle(String.valueOf(m.get("hour")));
			compVo.setCount(Long.parseLong(String.valueOf(m.get("count"))));
			dataList.add(compVo);
		});

		//已有的时间转成map
		Map<String, Long> mapData = dataList.stream()
				.collect(Collectors.toMap(WorkProcessCompleteVo::getCycle, WorkProcessCompleteVo::getCount));
		//已有的时间的和
		Long total = dataList.stream().collect(Collectors.summingLong(WorkProcessCompleteVo::getCount));

		//时间段格式转化
		DateTimeFormatter df = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");

		List<LocalDateTime> list = new ArrayList<>();
		List<WorkProcessCompleteVo> listResult = new ArrayList<>();
		
		//String转LocalDateTime 
		LocalDateTime startDate = LocalDateTime.parse(startTime, df);
		LocalDateTime endDate = LocalDateTime.parse(endTime, df);
           
           //得到时间段内的所有小时数(24小时制,查询条件是一天内)
		long distance = ChronoUnit.HOURS.between(startDate, endDate);
		//时间段相减小于1  就返回
		if (distance < 1) {
		    //把数据库查出数据放入返回实体类中
			reportVo.setDetail(dataList);
			reportVo.setTotal(total);
			return reportVo;
		}
		//把查出所有小时放入list里
		Stream.iterate(startDate, d -> d.plusHours(1)).limit(distance + 1).forEach(f -> {
			list.add(f);
		});
		list.forEach(l -> {
			WorkProcessCompleteVo completeVo = new WorkProcessCompleteVo();
			completeVo.setCycle(df.format(l).substring(11, 13) + ":00");
			completeVo.setCount(0L);
			listResult.add(completeVo);
		});

		//sql查出数据通过遍历放入所有时间list里
		listResult.stream().map(a -> {
			if (mapData.containsKey(a.getCycle())) {
				a.setCount(mapData.get(a.getCycle()));
			}
			return a;
		}).collect(Collectors.toList());

           //返回数据
		reportVo.setDetail(listResult);
		reportVo.setTotal(total);

		return reportVo;

	} else if (CycleType.DAY.equals(cycle)) {
		comList = workOrderProcessRepositoryDsl.queryCompleteDay(startTime, endTime);

		// 获取现有的天数
		comList.forEach(m -> {
			WorkProcessCompleteVo compVo = new WorkProcessCompleteVo();
			compVo.setCycle(String.valueOf(m.get("day")));
			compVo.setCount(Long.parseLong(String.valueOf(m.get("count"))));
			dataList.add(compVo);
		});

		// 转成map
		Map<String, Long> mapData = dataList.stream()
				.collect(Collectors.toMap(WorkProcessCompleteVo::getCycle, WorkProcessCompleteVo::getCount));
		
		Long total = dataList.stream().collect(Collectors.summingLong(WorkProcessCompleteVo::getCount));

		// 获取时间段内所有时间
		DateTimeFormatter df = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");

		List<LocalDateTime> list = new ArrayList<>();
		List<WorkProcessCompleteVo> listResult = new ArrayList<>();

		LocalDateTime startDate = LocalDateTime.parse(startTime, df);
		LocalDateTime endDate = LocalDateTime.parse(endTime, df);

		long distance = ChronoUnit.DAYS.between(startDate, endDate);
		if (distance < 1) {
			reportVo.setDetail(dataList);
			reportVo.setTotal(total);
			return reportVo;
		}
		Stream.iterate(startDate, d -> d.plusDays(1)).limit(distance + 1).forEach(f -> {
			list.add(f);
		});
		// 所有时间
		list.forEach(l -> {
			WorkProcessCompleteVo completeVo = new WorkProcessCompleteVo();
			completeVo.setCycle(df.format(l).substring(0, 10));
			completeVo.setCount(0L);
			listResult.add(completeVo);
		});

		// 整合数据
		listResult.stream().map(a -> {
			if (mapData.containsKey(a.getCycle())) {
				a.setCount(mapData.get(a.getCycle()));
			}
			return a;
		}).collect(Collectors.toList());

		reportVo.setDetail(listResult);
		reportVo.setTotal(total);

		return reportVo;

	} else if (CycleType.MONTH.equals(cycle)) {
		comList = workOrderProcessRepositoryDsl.queryCompleteMonth(startTime, endTime);

		// 获取现有的月份
		comList.forEach(m -> {
			WorkProcessCompleteVo compVo = new WorkProcessCompleteVo();
			compVo.setCycle(String.valueOf(m.get("month")));
			compVo.setCount(Long.parseLong(String.valueOf(m.get("count"))));
			dataList.add(compVo);
		});

		// 转成map
		Map<String, Long> mapData = dataList.stream()
				.collect(Collectors.toMap(WorkProcessCompleteVo::getCycle, WorkProcessCompleteVo::getCount));
		
		Long total = dataList.stream().collect(Collectors.summingLong(WorkProcessCompleteVo::getCount));

		// 获取时间段内所有时间
		DateTimeFormatter df = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");

		List<LocalDateTime> list = new ArrayList<>();
		List<WorkProcessCompleteVo> listResult = new ArrayList<>();

		LocalDateTime startDate = LocalDateTime.parse(startTime, df);
		LocalDateTime endDate = LocalDateTime.parse(endTime, df);

		long distance = ChronoUnit.MONTHS.between(startDate, endDate);
		if (distance < 1) {
			reportVo.setDetail(dataList);
			reportVo.setTotal(total);
			return reportVo;
		}
		Stream.iterate(startDate, d -> d.plusMonths(1)).limit(distance + 1).forEach(f -> {
			list.add(f);
		});
		// 所有时间
		list.forEach(l -> {
			WorkProcessCompleteVo completeVo = new WorkProcessCompleteVo();
			completeVo.setCycle(df.format(l).substring(0, 7));
			completeVo.setCount(0L);
			listResult.add(completeVo);
		});

		// 整合数据
		listResult.stream().map(a -> {
			if (mapData.containsKey(a.getCycle())) {
				a.setCount(mapData.get(a.getCycle()));
			}
			return a;
		}).collect(Collectors.toList());

		reportVo.setDetail(listResult);
		reportVo.setTotal(total);

		return reportVo;

	} else if (CycleType.YEAR.equals(cycle)) {
		comList = workOrderProcessRepositoryDsl.queryCompleteYear(startTime, endTime);

		// 获取现有的年
		comList.forEach(m -> {
			WorkProcessCompleteVo compVo = new WorkProcessCompleteVo();
			compVo.setCycle(String.valueOf(m.get("year")));
			compVo.setCount(Long.parseLong(String.valueOf(m.get("count"))));
			dataList.add(compVo);
		});

		// 转成map
		Map<String, Long> mapData = dataList.stream()
				.collect(Collectors.toMap(WorkProcessCompleteVo::getCycle, WorkProcessCompleteVo::getCount));
		
		Long total = dataList.stream().collect(Collectors.summingLong(WorkProcessCompleteVo::getCount));

		// 获取时间段内所有时间
		DateTimeFormatter df = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");

		List<LocalDateTime> list = new ArrayList<>();
		List<WorkProcessCompleteVo> listResult = new ArrayList<>();

		LocalDateTime startDate = LocalDateTime.parse(startTime, df);
		LocalDateTime endDate = LocalDateTime.parse(endTime, df);

		long distance = ChronoUnit.YEARS.between(startDate, endDate);
		if (distance < 1) {
			reportVo.setDetail(dataList);
			reportVo.setTotal(total);
			return reportVo;
		}
		Stream.iterate(startDate, d -> d.plusYears(1)).limit(distance + 1).forEach(f -> {
			list.add(f);
		});
		// 所有时间
		list.forEach(l -> {
			WorkProcessCompleteVo completeVo = new WorkProcessCompleteVo();
			completeVo.setCycle(df.format(l).substring(0, 4) + "年");
			completeVo.setCount(0L);
			listResult.add(completeVo);
		});

		// 整合数据
		listResult.stream().map(a -> {
			if (mapData.containsKey(a.getCycle())) {
				a.setCount(mapData.get(a.getCycle()));
			}
			return a;
		}).collect(Collectors.toList());

		reportVo.setDetail(listResult);
		reportVo.setTotal(total);

		return reportVo;
	}
	return null;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值