无法将 '0000-00-00 00:00:00' 转换为时间戳

2022-09-01 12:37:19

字段定义

 /** Date. */
  @Column(columnDefinition = "datetime")
  private Date date;

二传手

public void setDate(final Date date) {
    DateFormat dfmt = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
    try {
      this.date = dfmt.parse(dfmt.format(date));
    } catch (ParseException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    }

  }

有没有人知道如何将“零日期”转换为适当的值?因为我有错误:

Cannot convert value '0000-00-00 00:00:00' from column 13 to TIMESTAMP

即使我设置了“默认”字段和设置器,如下所示:

/** Date. */
      @Column
      private Date date;


public void setDate(final Date date) {
      this.date = date;   
  }

我仍然会有同样的问题....


答案 1

我将在这里疯狂猜测你正在使用MySQL:-)它使用“零日期”作为特殊占位符 - 不幸的是,JDBC默认情况下无法处理它们。

解决方案是指定“zeroDateTimeBehavior=convertToNull”作为MySQL连接的参数(在数据源URL中或作为附加属性),例如:

jdbc:mysql://localhost/myDatabase?zeroDateTimeBehavior=convertToNull

这将导致所有此类值作为 NULL 进行检索。


答案 2

我不明白你的代码中的要点,你格式化然后再次解析一个日期。这似乎是一个相同的操作。也许你可以详细说明?


如果要为日期指定默认值,可以执行以下操作:

/** Jan 1, 1970 ; first moment in time in Java */
private static final Date NO_DATE = new Date(0L);

private Date date;

public void setDate(final Date date) {
     if (date == null) {
         this.date = NO_DATE;
     } else {
         this.date = date;
     }
}

注意:注释是可选的,这里我没有添加它们。

在此代码中,可以将所需的内容替换为条件和默认值。

您还可以添加一个类似的 setter,它将采用 String 参数,并检查您的特殊“00000...”值。这将允许使用日期或字符串设置字段。