加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

时间戳Unix timestamp

发布时间:2020-12-15 23:01:13 所属栏目:安全 来源:网络整理
导读:? (1)定义 Unix时间戳(Unix timestamp),或称Unix时间(Unix time)、POSIX时间(POSIX time),是一种时间表示方式,定义为从格林威治时间1970年01月01日00时00分00秒( 北京时间1970年01月01日08时00分00秒) 起至现在的总秒数。Unix时间戳不仅被使用在Unix

?

(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秒(二进制:02222211 22222111 22222111 22222111)。其后一秒,二进制数字会变为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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读