时间戳Unix timestamp

 

(1)定义

Unix时间戳(Unix timestamp),或称Unix时间(Unix time)、POSIX时间(POSIX time),是一种时间表示方式,定义为从格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总秒数。Unix时间戳不仅被使用在Unix 系统、类Unix系统中,也在许多其他操作系统中被广泛采用。

目前相当一部分操作系统使用32位二进制数字表示时间。此类系统的Unix时间戳最多可以使用到格林威治时间2038年01月19日03时14分07秒(二进制:01111111 11111111 11111111 11111111)。其后一秒,二进制数字会变为10000000 00000000 00000000 00000000,发生溢出错误,造成系统将时间误解为1901年12月13日20时45分52秒。这很可能会引起软件故障,甚至是系统瘫痪。使用64位二进制数字表示时间的系统(最多可以使用到格林威治时间292,277,026,596年12月04日15时30分08秒)则基本不会遇到这类溢出问题。

(2)10位与13位时间戳

a.产生

 java的date默认精度是毫秒,也就是说生成的时间戳就是13位的,而像c++或者php生成的时间戳默认就是10位的,因为其精度是秒。

【1秒=1000毫秒,1毫秒=1000微秒】

b.转换方法

第一种:通过substring方法,将13位的时间戳最后三位数字截取 
第二种:将13位时间戳除以1000      -- 此方法更可取

HIVE/SPARK:

select unix_timestamp()    -- 当前时间的时间戳,10位

扫描二维码关注公众号,回复: 5102930 查看本文章

select from_unixtime(1548654394172/1000)   --时间精确到秒:2019-01-28 13:46:34

PRESTO:

select to_unixtime(current_timestamp)     -- 当前时间的时间戳,长度14位(包含小数点)

select from_unixtime(1548654394172/1000)    --时间会精确到毫秒:2019-01-28 13:46:34.000

参考链接:

什么是时间戳:http://www.cnblogs.com/yangqi/archive/2010/07/16/1778675.html

UNIX时间戳:https://baike.baidu.com/item/unix%E6%97%B6%E9%97%B4%E6%88%B3/2078227

猜你喜欢

转载自www.cnblogs.com/wxyz94/p/10329889.html