【发布时间】:2019-04-27 22:30:58
【问题描述】:
我阅读了 ZonedDate 和 Instant 的文献,发现我可以通过以下方式将本地时间转换为 UTC:
LocalDate d = LocalDate.now();
LocalTime time = LocalTime.of(00, 00, 00);
ZoneId zone = ZoneId.systemDefault();
ZonedDateTime zonedDateTime = ZonedDateTime.of(d, time, zone);
System.out.println(zonedDateTime.format(DateTimeFormatter.ISO_LOCAL_DATE_TIME));
Instant instant = zonedDateTime.toInstant();
System.out.println(instant);
问题是输出看起来像这样:
2018-11-26T00:00:00
2018-11-26T08:00:00Z
我正在尝试以“yyyy-MM-dd HH:mm:ss”的格式获取两个字符串,但是很难让任何东西正常工作。由于我使用输出来查询 MYSQL 数据库,我可以手动执行:
String zoneDate = zonedDateTime.format(DateTimeFormatter.ISO_LOCAL_DATE_TIME);
String utcDate = zonedDateTime.toInstant().toString();
zoneDate = zoneDate.replace('T', ' ').replace('Z', ' ');
utcDate = utcDate.replace('T', ' ').replace('Z', ' ');
我的新输出是:
2018-11-26 00:00:00
2018-11-26 08:00:00
但我觉得这是不好的做法,应该有一种方法可以在类中转换为正确的格式。有没有这样一种方法可以从默认类中执行上述格式化?
【问题讨论】:
-
System.out.println(instant);将调用Instant.toString(),因此您一定会使用返回的内容。相反,您应该使用格式化程序来生成格式化字符串,就像使用zonedDateTime.format(...)一样,例如通过DateTimeFormatter.ISO_LOCAL_DATE_TIME.format(instant). -
我明白,但问题是我无法为 MYSQL 日期时间对象找到合适的格式化程序,如上表所示。我正在调用 toString() 方法,因为如果在声明中设置它,则需要获取字符串本身。您描述的执行 DateTimeFormatter.ISO_LOCAL_DATE_TIME.format(instant) 的方法会引发异常并且堆栈跟踪状态为“java.time.temporal.UnsupportedTemporalTypeException: Unsupported field: Year”
-
您可能需要使用其他格式化程序或定义自己的格式。除了将字符串传递给 MySQL 可能不是最好的方法之外,我会尝试将
Instant转换为java.sql.Date或类似的东西(取决于驱动程序支持的内容,我没有使用普通的 JDBC过一会儿)。 -
如果您的 JDBC 驱动程序不接受未格式化的
Instant,给它一个OffsetDateTime并完全不用担心格式。这是正确的方法,也是一种简单且无故障的方法。也不要使用两位数00。虽然它在视觉上令人愉悦并且可以工作,但使用08或09将无法编译,因此这是一个不好的习惯。
标签: java mysql datetime date-formatting