时间戳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秒(二进制: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位的时间戳最后三位数字截取? ? 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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |