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

博客讲述了在处理时间字段时遇到的问题,特别是当时间精度提升到纳秒时,SimpleDateFormat无法正确处理。作者转向使用Java 8引入的java.time包,特别是DateTimeFormatter,来解决精度丢失的问题,并提供了日期和时间的转换示例。
772

被折叠的 条评论
为什么被折叠?



