无法将'0000-00-00 00:00:00'转换为TIMESTAMP

时间:2009-09-01 16:49:23

标签: java hibernate date hql

字段定义

 /** 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;   
  }

我仍然会遇到同样的问题......

2 个答案:

答案 0 :(得分:67)

我将在这里猜测你正在使用MySQL :-)它使用“零日期”作为special placeholder - 不幸的是,JDBC默认无法处理它们。

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

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

这将导致所有这些值被检索为NULL。

答案 1 :(得分:3)

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


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

/** 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 ...”值。这将允许使用Date或String设置字段。