字段定义
/** 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;
}
我仍然会遇到同样的问题......
答案 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设置字段。