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

时间:2012-07-31 12:57:39

标签: java timestamp simpledateformat

我正在尝试使用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.fffffffff字符串的问题,我对声明方法很感兴趣,即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) failed
  • 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 < / em>的。 ( 427000000 的纳秒部分被视为毫秒,即使只指定了SSS)

3 个答案:

答案 0 :(得分:2)

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

这里的问题是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());   

修改

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

答案 1 :(得分:1)

编辑:既然您已经为我们提供了数据样本,那就相当简单了:

"yyyy-MM-dd HH:mm:ss.SSS"

这肯定会解析你所给予的价值。您可能还想明确指定Locale.US,这样就不会尝试使用不同的分隔符......

编辑:超过毫秒的尾随数据会导致问题。但是,数据的早期部分是固定长度(我相信23个字符),所以你应该能够写:

Date date = format.parse(text.substring(0, 23));

答案 2 :(得分:0)

RFC3339的日期格式为格式:

yyyy-MM-dd'T'HH:mm:ss.SSS'Z'

除非您有来自资源提供者的不同日期格式。'

如果你有小数秒:

yyyy-MM-dd'T'HH:mm:ss.SSSSSS'Z'

编辑:根据您的示例,我解析您的字符串的格式是:

DateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSSSSSSSS");