从解析日期(时区问题)中获取正确的长值

dra*_*ayn 5 java oracle-adf

我正在尝试从String解析日期并获取long值.long值将稍后发送到SQL查询.

这是我的代码:

String dayDate = "28-02-2013";            
SimpleDateFormat sdf = new SimpleDateFormat("dd-MM-yyyy");
Date day = new Date();
try {
    day = sdf.parse(dayDate);
} catch (ParseException pe) {
    pe.printStackTrace();
}
System.out.println("day : "+day.toString()+ "  long : " + day.getTime());
Run Code Online (Sandbox Code Playgroud)

它给出了以下输出:

day : Thu Feb 28 00:00:00 EET 2013  long : 1362002400000
Run Code Online (Sandbox Code Playgroud)

这是正确的,但不是我想要的,因为长值导致2013年2月27日星期三22:00:00 GMT(http://www.epochconverter.com/)(我在GMT + 2时区).我需要发送纠正sql的长值.

反正有没有使用外部库来解决这个问题?

n0r*_*m1e 5

SimpleDateFormat是区域设置感知的,这意味着它解析的日期在您的时区中.格林尼治标准时间2月28日午夜2点实际上是格林尼治标准时间2月27日晚上10点,长值1362002400000.我会添加这个以获得正确的解析(不会打扰使用日历):

sdf.setTimeZone(TimeZone.getTimeZone("GMT"))
Run Code Online (Sandbox Code Playgroud)

同样,当您打印此日期时,它使用SimpleDateFormat,这就是您可以在输出中看到EET的原因.

将此传递给数据库是一个不同的故事,但一旦你做对了.