获取时间段内所有的(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;
}
#include<reg52.h> #include<stdio.h> /*日期和时间变量*/ unsigned char sec=0; unsigned char min=0; unsigned char hour=0; unsigned char day=1; unsigned char month=1; unsigned char year=2023; /*定时器初始化*/ static void InitTimer0() { TMOD &= 0xF0; //设置定时器模式 TMOD|=0x01;//设置定时器0为工作模式1 TF0=0; TR0=1; TL0 = 0x18; //设置定时初始值 TH0 = 0xFC; //设置定时初始值 ET0=1;//允许中断 EA=1;//允许总中断 PT0=0; } /*串口初始化*/ static void InitUART() { SCON=0x50;//设置串口模式为8位数据 TMOD|=0x20;//设置定时器1为模式2 PCON=0x80;//设置波特率为双倍 TL1=0xFA;//设置定时器初始值 TH1=TL1;//设置定时器初始值 TR1=1;//启动定时器1 TI=1;//设置发送标志位 ES=1;//启用串口中断 } /*串口发送字符串*/ void UART_SendString(char*str) { while(*str) { SBUF=*str++; while(!TI); TI=0; } } /*中断处理程序*/ void Timer0_Handler() interrupt 1 { sec++; if(sec>=60) { sec=0; min++; if(min>=60) { min=0; hour++; if(hour>=24) { hour=0; day++; if((month==1||month==3||month==5||month==7||month==8||month==10||month==12)&&day>31) { day=1; month++; } else if((month==4||month==6||month==9||month==11)&&day>30) { day=1; month++; } else if(month==2&&((year%4==0&&year%100!=0)||year%400==0)&&day>29) { day=1; month++; } else if(month==2&&day>28) { day=1; month++; } if(month>12) { month=1; year++; } } } } } /*延时函数*/ void delay_ms(unsigned int ms) { unsigned int i,j; for(i=0;i<ms;i++) { for(j=0;j<120;j++) { } } } /*主函数*/ void main() { InitTimer0();//初始化中断 InitUART();//串口初始化 while(1) { char time_str[50]; sprintf(time_str,"Date: %d-%d-%d Time:%02d:%02d:%02d\n",year,month,
最新发布
03-12
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值