标签:精确 hive -- presto target lan res 使用 aik
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秒)则基本不会遇到这类溢出问题。
a.产生
java的date默认精度是毫秒,也就是说生成的时间戳就是13位的,而像c++或者php生成的时间戳默认就是10位的,因为其精度是秒。
【1秒=1000毫秒,1毫秒=1000微秒】
b.转换方法
第一种:通过substring方法,将13位的时间戳最后三位数字截取
第二种:将13位时间戳除以1000 -- 此方法更可取
HIVE/SPARK:
select unix_timestamp() -- 当前时间的时间戳,10位
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
标签:精确 hive -- presto target lan res 使用 aik
原文地址:https://www.cnblogs.com/wxyz94/p/10329889.html