当前位置:网站首页>时间戳格式化「建议收藏」
时间戳格式化「建议收藏」
2022-08-02 15:57:00 【全栈程序员站长】
大家好,又见面了,我是你们的朋友全栈君。
一、须知:
1. 纯数字时间戳分2种,一种是10位的,只包含年月日时分秒,也就是说,只精确到秒。一种是13位的,包含毫秒。这2种都叫时间戳,并不是只有精确到毫秒的才叫时间戳。
10位时间戳就是从1970-01-01到当前的秒数,注意,不是毫秒数
,所以需要按毫秒解析时,要 * 1000
13位时间戳就是从1970-01-01到当前的毫秒数
,在java中用Instant对象对应。
2. timestamp的格式化串用大写的S
来表示毫秒数。S的个数和毫秒的位数严格对应,否则报错。如果规范中要求精确到毫秒,那么给的时间字符串,那肯定是3位。给2位精确不到毫秒,给4位,获取到的毫秒数也不会包含毫秒之外的信息。
@Test
def tt3(): Unit = {
val dtf = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss.SSS")
//时间戳和时间对象互转
println(LocalDateTime.parse("2020-04-04 08:08:08.123", dtf).toInstant(ZoneOffset.of("+8")).toEpochMilli) //1585958888123
println(LocalDateTime.ofInstant(Instant.ofEpochMilli(1585958888123L), ZoneOffset.of("+8"))) //2020-04-04T08:08:08.123
//这2个值是一样的,上面的解析秒,下面的是 * 1000 后解析毫秒
println(LocalDateTime.ofEpochSecond(1585958888L, 0, ZoneOffset.ofHours(8))) //2020-04-04T08:08:08
println(LocalDateTime.ofInstant(Instant.ofEpochMilli(1585958888000L), ZoneOffset.of("+8"))) //2020-04-04T08:08:08
}
3. LocalDateTime.ofEpochSecond(1585958888L, 0, ZoneOffset.ofHours(8))用来把秒数转为时间对象。LocalDateTime.ofInstant(Instant.ofEpochMilli(1585958888000L), ZoneOffset.of(“+8”))用来把毫秒数转为时间对象。Epoch的意思是从1970-01-01开始。
二、Hive中对时间戳的支持
Hive并没有提供13位时间戳的转换函数,但是load的时候,会自动识别形如”2020-04-04 08:08:08.123″这种带毫秒数的时间戳,会正常导入且能正常显示和使用。
Hive中10位纯数字时间戳的转换: https://www.cnblogs.com/dcx-1993/p/11359139.html
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/125151.html原文链接:https://javaforall.cn
边栏推荐
猜你喜欢
随机推荐
MongoDB 《三》复制集集群搭建实例
Qt reads Json files (including source code + comments)
亏损扩大/毛利偏低,北斗智联与「智能座舱第一阵营」的不等号
总结:不同语言比较总结
Qt读取Json文件(含源码+注释)
【[SCOI2005] 互不侵犯】【状压DP(含概念讲解)】
uniapp 小程序 动态style class
QueryWrapper方法解释
A tour of gRPC: 06 - gRPC client straming
ROS人机交互软件
AI+BI+可视化,Sugar BI架构深度剖析
【暑期集训第一周:搜索】【DFS&&BFS】
2.6 - 进程资源
“如何写好一篇学术论文?”这大概是最详实的一则攻略了!
一文搞懂│php 中的 DI 依赖注入
05-读写锁、阻塞队列及四组API、同步队列
一文搞懂│php 中的 DI 依赖注入
2.3 - P、V、S机制
ICML/ICLR'22 推荐系统论文梳理
[LeetCode]剑指 Offer 54. 二叉搜索树的第k大节点