在项目中我们可能需要统计昨日零点至今日零点的数据,这时需要根据当前时间计算零点时间。
- SQL 获取零点时间 (Vertica)
-- 获取昨日零点时间
select extract(epoch from timestamp 'yesterday');
-- 获取今日零点时间
select extract(epoch from timestamp 'today');
-- 获取明日零点时间
select extract(epoch from timestamp 'tomorrow');
- Java 获取零点时间
// 今日零点
LocalDateTime zeroTime = LocalDateTime.of(LocalDate.now(), LocalTime.MIN);
// 昨日零点
LocalDateTime y_zeroTime = LocalDateTime.of(LocalDate.now().minusDays(1),
LocalTime.MIN);
- Shell 获取零点时间
# 当天零点时间
# 86400为一天的秒数
time=`date +%s`
# 今日零点时间
ZERO_TIME=$(((${time}+3600*8)/86400*86400-3600*8))
# 昨日零点时间
Y_ZERO_TIME=${ZERO_TIME} - 86400
解释:首先,在世界上任何地方,任何时间,得到的时间戳都是相同的。但计算时间戳的起始时间不同。
格林尼治时间从1970-00:00:00开始,对于东八区来说,可以认为时间戳起始时间为1970-08:00:00,因此通过时间戳计算天数时需要先将时间戳加上8小时,除以86400得到天数,再乘以86400得到时间戳。
注意,此时的时间戳是以起始时间为1970-00:00:00计算得到的,因此需要减去8小时得到东八区的零点时间