Java-日期保存为前一天


问题内容

在将日期保存到数据库时,我遇到一种非常奇怪的行为。在我的(Linux centOS
6.2)服务器上,我使用glassfish应用程序服务器(3.1.1-内部版本12)和Java(1.7.0_09),该应用程序是使用Java +
GWT开发的,并且使用PostgreSQL服务器(9.2.1)。在应用程序内部,有几个保存在数据库中的日期字段。日期字段使用datepicker(http://code.google.com/p/gwt-
datepicker,r30)。

db关系的date属性是日期类型(不是时间戳)。一些日期会在数据库的前一天保存。问题仅在间隔之间的日期发生,例如1968年3月31日至1968年10月27日之间,这使我想到了某种夏季时间问题。但是,由于例如在1969年没有发生这种情况,因此我无法很好地隔离问题。我试图找到发生问题的其他日期间隔。
例如,如果我在应用程序中选择19.05.1968,则在数据库中保存日期后,日期将另存为18.05.1968。

奇怪的是,我在另一台服务器上具有同一应用程序的另一种情况,并且对于相同的日期,它们可以正确保存。这使我认为问题可能取决于:

  • 玻璃鱼配置;
  • java(java.util.Date实现吗?);
  • 我缺少某种服务器配置

我试图将服务器的所有配置都设置为Europe / Rome(我的时区),但是没有任何设置。任何想法?我该如何解决或调查这个问题?

更新: 1968年是a年。这个问题也发生在1972年,这又是a年。总结: “保存日期前一天”问题发生在夏季时间日期间隔的leap年中。

创建日期对象的代码部分是:

Date d = dateField.getSelectedDate();
if (d != null) {
    txtVal = DateTimeFormat.getFormat("dd/MM/yyyy").format(d);
}

dateField声明为:

transient private DatePicker dateField;

包是org.zenika.widget.client.datePicker.DatePicker(前面提到的gwt-
datepicker-r30),DateTimeFormat是指com.google.gwt.i18n.shared.DateTimeFormat

接受答案后进行更新:

我使用了这种解决方法:创建日期时,我使用以下代码:

final long hours12 = 12L * 60L * 60L * 1000L;
Date d = new Date(d1.getTime() + hours12);

问题答案:

只需将日期时间设置为12:00(而不是默认的0:00),就可以了。问题在于GWT时区库不包括1990年之前的所有leap年,因此您在服务器上的时间错误(因为该值是以时间戳的形式发送的,并且会减少一小时)。

顺便说一句:GWT具有内置的日期选择器,请访问http://gwt.google.com/samples/Showcase/Showcase.html#!CwDatePicker查看其演示。