sql实现--根据不同类型的时间戳按24小时每小时统计数据,并补齐数据和取整

本文介绍如何将两种不同格式的时间戳转换为24小时制,并通过编程实现确保每天各小时段数据完整性的方法。文章详细展示了从UNIX时间戳到24小时制的转换过程,以及如何处理自定义格式的时间戳。此外,还提供了补全24小时数据的代码示例,以确保数据分析的连续性和完整性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

两种不同的时间戳转换成24小时
第一种:1546308369067(标准时间戳)
FROM_UNIXTIME(C.RECHARGE_TIME/1000,’%H’) AS DATE_NO

第二种:20181205193346(自定义时间戳)
SUBSTR(W.BUYCOIN_TIME,9,2) AS DATE_NO

补齐24小时没有数据的小时(永远24条数据)

//一天24小时消费时段分析曲线
List<CspPeriod> cspPeriods = new ArrayList<CspPeriod>();
			for (int cspPeriods1 = 1; cspPeriods1 < 25; cspPeriods1++) {
				CspPeriod cspPeriod = new CspPeriod();
				cspPeriod.setDateNo(cspPeriods1);
				cspPeriod.setConsumption(0L);
				cspPeriods.add(cspPeriod);
			}
List<CspPeriod> cardRechargeLog = incomeCurveMapper.getCardRechargeLog(param);
if (cardRechargeLog !=null && cardRechargeLog.size()>0 && cardRechargeLog.get(0) != null) {
				for (CspPeriod cspPeriod : cspPeriods) {
					for (CspPeriod cardRecharge : cardRechargeLog) {
						if (cspPeriod.getDateNo()==cardRecharge.getDateNo()) {
							cspPeriod.setConsumption(cardRecharge.getConsumption());
						}
					}
				
				}
			}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值