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

问题背景:

根据时间字段拉取数据,由于平时测试环境时间字段都是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());

 直接起飞!!!!!

你可能感兴趣的:(Java,学习,java,时间格式化)