0

我的 java 程序有问题。

我正在使用时间戳对数据库执行查询,但我得到了错误的时间戳。

在我的虚拟机上,我将日期设置为太平洋时间:

date

Wed Oct 30 09:50:43 PDT 2013

timedatectl status

  Local time: Wed 2013-10-30 09:52:30 PDT
Universal time: Wed 2013-10-30 16:52:30 UTC
    Timezone: US/Pacific (PDT, -0700)
 NTP enabled: yes
NTP synchronized: no
RTC in local TZ: no
     DST active: yes
 Last DST change: DST began at
                 Sun 2013-03-10 01:59:59 PST
                 Sun 2013-03-10 03:00:00 PDT
 Next DST change: DST ends (the clock jumps one hour backwards) at
              Sun 2013-11-03 01:59:59 PDT
              Sun 2013-11-03 01:00:00 PST

但是当我的程序执行 system.getCurrentMilis() 时返回以下时间戳:

2013-10-30 11:47:16.884

我不确定为什么会这样。如果有人能告诉我出了什么问题或者我可以检查什么,那就太棒了

谢谢!

编辑:

//- Get maximum timestamp from previous query
Timestamp maxTimestamp = (new Timestamp( System.currentTimeMillis() ) ;


//- Compute query parameters (see notes above)
Timestamp lowerLimit = new Timestamp( maxTimestamp.getTime() - 500) ;
System.out.println("lowerLimit=" + lowerLimit ) ;
Timestamp upperLimit = new Timestamp( System.currentTimeMillis());
System.out.println("upperLimit=" + upperLimit ) ;
4

1 回答 1

0

system.getCurrentMilis() 给出从 1970 年初开始的 GMT 长表示量 ms。当您将其解析为字符串时,您很可能会通过时区和夏令时对其进行调整。

于 2013-10-30T17:43:11.983 回答