gpt4 book ai didi

java - Java中的JDBC时间戳转义格式和SimpleDateFormat

转载 作者:行者123 更新时间:2023-12-04 00:45:13 30 4
gpt4 key购买 nike

我正在尝试提出 SimpleDateFormat 模式来解析和格式化 JDBC 时间戳,特别是以下格式的日期 yyyy-mm-dd hh:mm:ss.fffffffff,其中 ffffffffff 表示纳秒。

不幸的是 new SimpleDateFormat("yyyy-MM-dd-HH.mm.ss.SSS000000") 不起作用,抛出以下异常:

java.text.ParseException: Format.parseObject(String) failed

这完全可以用 SimpleDateFormat 实现,还是我必须创建 java.text.DateFormat 的自定义子类来处理这种情况? 请注意 这不是关于如何在 Java 中解析 yyyy-mm-dd hh:mm:ss.ffffffffff 字符串的问题,我对声明式方法感​​兴趣,即不需要对输入字符串进行额外修改的 SimpleDateFormat 模式。

示例:

我希望输入 2012-02-05 17:00:34.427000000被解析为 java.util.Date,其中毫秒部分为 427

这是我迄今为止尝试过的格式列表,但由于各种原因它们都失败了:

  • new SimpleDateFormat("yyyy-MM-dd-HH.mm.ss.SSS000000") - java.text.ParseException: Format.parseObject(String) 失败
  • new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSSSSSSSS", Locale.US)new SimpleDateFormat("yyyy-MM-dd HH:mm: ss.SSS", Locale.US) - 被解析为 Fri Feb 10 15:37:14 而不是预期的 Sun Feb 05 17:00:34。 (427000000 的纳秒部分被视为毫秒,即使只指定了 SSS)

最佳答案

我知道这是一个迟到的答案,但我一直在研究类似的问题并且遇到了这个问题。

这里的问题是 SimpleDateFormat 需要一个没有纳秒字段的 java.util.Date。所以,它不处理这种情况。 java.sql.Timestamp文档说它是 java.util.Date 和纳秒字段的组合。 的日期/时间值存储在对象的日期部分。这意味着可以忽略剩余的毫秒以支持纳秒字段。在我看来,这是一个糟糕的设计,因为 java.sql.Timestampjava.util.Date 的直接子类。

无论如何,为了回答这个问题,我认为如果不附加到由 SimpleDateFormat 生成的字符串,就不可能打印纳秒级的时间戳。

这是一种方法:

    Timestamp timestamp = new Timestamp(System.currentTimeMillis());
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd-HH.mm.ss.");
format.setTimeZone(TimeZone.getDefault()); // Set the TimeZone to whatever you are expecting.

System.out.println(format.format(timestamp) + String.format("%09d", timestamp.getNanos());

编辑:

为纳秒字符串值添加了填充。

关于java - Java中的JDBC时间戳转义格式和SimpleDateFormat,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11740645/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com