当前位置: 首页 > 面试题库 >

Java-日期保存为前一天

堵宪
2023-03-14
问题内容

在将日期保存到数据库时,我遇到一种非常奇怪的行为。在我的(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查看其演示。



 类似资料:
  • 我想以MM-dd-yy格式显示当前日期 现在,我想更改为mm-dd-yy模式

  • 我尝试使用spark将一些数据保存到casandra,但当我尝试保存日期时,我得到了 出现以下错误: 我的餐桌课 我的cassandra表: 有人知道怎么解决这个问题吗? 编辑:

  • 问题内容: 我已经进行了所有设置,将当前日期存储到Java中的变量中。我要弄清楚的是如何存储当前日期之后1年的日期。 这是我当前的日期: 因此,例如,如果今天是今天,它将存储2/18/2013。我正在尝试存储日期2/18/2014。我将如何去做呢? 问题答案: 如果您不想拖动外部库,只需使用 请注意,如果日期是,并且您添加了1年,则将获得

  • Db是MySQL 5.0,Yii版本1.1.12。 如果有任何帮助,我将不胜感激,我几乎被卡住了.....谢谢...

  • 我已经在我的应用程序中添加了一个按钮。当我点击按钮时,当前时间保存到SP。但我想把这个保存到我的firebase数据库里。我怎么能这么做?

  • 问题内容: 我假设Java有一些内置的方法可以做到这一点。 给定日期,我如何确定该日期之前一天? 例如,假设给我3/1/2009。上一个日期是2009年2月28日。如果给我3/1/2008,那么以前的日期应该是2/29/2008。 问题答案: 使用日历界面。 以这种方式进行“加法”可确保您获得有效的日期。该日期也于一年的1月1日有效,例如2012年1月1日为2011年12月31日。