码迷,mamicode.com
首页 > 其他好文 > 详细

时间戳Unix timestamp

时间:2019-01-28 15:16:16      阅读:235      评论:0      收藏:0      [点我收藏+]

标签:精确   hive   --   presto   target   lan   res   使用   aik   

 

(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位

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

 

时间戳Unix timestamp

标签:精确   hive   --   presto   target   lan   res   使用   aik   

原文地址:https://www.cnblogs.com/wxyz94/p/10329889.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!