关于SimpleDateFormat格式化无法精确到微妙、纳秒的处理

13 篇文章 1 订阅

问题背景:

根据时间字段拉取数据,由于平时测试环境时间字段都是DATE类型精度为0,用

SimpleDateFormat格式化为yyyy-MM-dd hh:mm:ss然后拼接sql查询没有问题;但是前几天别人提供的数据为timestamp精度设置为6时间如:2022-01-21 11:07:18.123456,采用上面这种格式化日期后丢失精度导致数据缺失。

面向百度编程。。。

结果大家都说后面秒要几位小数就写几个S 于是乎我改成了yyyy-MM-dd hh:mm:ss.SSSSSS

结果格式化出来的时间成了2022-01-21 11:07:18.000123

这也不行啊!!!

又经过一番百度,有个人说的好像靠谱点:

不,您不能使用SimpleDateFormat来处理纳秒。 但是你的前提是…… Java does not support time granularity above milliseconds in its date patterns Ok. …从Java 8、9、10及更高版本开始,内置Java.time类不再适用。 Java 6和Java 7也并非如此,因为大多数java.time功能都是反向移植的。 java.time SimpleDateFormat和相关的java.util.Date / .Calendar类现在已被Java 8(教程)中新的java.time包取代。 新的java.time类支持纳秒分辨率。该支持包括解析并生成9位数的小数秒。例如,当您使用java.time.format DateTimeFormatter API时,S模式字母表示"秒的分数"而不是"毫秒",它可以处理纳秒的值。

此处奉上DateTimeFormatter用法:

//字符串转换为日期
String dateStr= "2018年12月18日";
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy年MM月dd日");
LocalDate date= LocalDate.parse(dateStr, formatter);
 
//日期转换为字符串
LocalDateTime now = LocalDateTime.now();
DateTimeFormatter format = DateTimeFormatter.ofPattern("yyyy年MM月dd日 HH:mm:ss");
String nowStr = now.format(format);
 
Instant:瞬时实例。
LocalDate:本地日期,不包含具体时间。
LocalTime:本地时间,不包含日期。
LocalDateTime:组合了日期和时间,但不包含时差和时区信息。
ZonedDateTime:最完整的日期时间,包含时区和相对UTC或格林威治的时差。
 
//Date转LocalDateTime
Instant instant = date.toInstant();
ZoneId zoneId = ZoneId.systemDefault();
Date date = instant.atZone(zoneId).toLocalDateTime();
 
//LocalDateTime转Date
ZoneId zoneId = ZoneId.systemDefault();
ZonedDateTime zdt = localDateTime.atZone(zoneId);
LocalDateTime localDateTime = Date.from(zdt.toInstant());

 直接起飞!!!!!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值