[英]Getting long value for two equal date times yields different values
我想使用日期时间作为MapReduce减少端连接程序中的键。 表A的值为2013-01-01 15:11:48
,表B的值为1-1-2013 15:11 GMT
。
我将A解析为:
DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); //2013-01-01 15:11:48
Calendar cal = Calendar.getInstance();
cal.setTime(df.parse(split[TaxiFields.PICKUP_DATETIME]));
cal.set(Calendar.SECOND, 0); //disconsidering the seconds
pickupDatetime.set(cal.getTime().getTime());
我将B解析为:
DateFormat df = new SimpleDateFormat("dd-MM-yyyy HH:mm zzz"); //1-1-2013 15:11 GMT,
Calendar cal = Calendar.getInstance();
cal.setTime(df.parse(split[0]));
cal.set(Calendar.SECOND, 0);
rainDate.set(cal.getTime().getTime());
但是第一个给我一个1357063860000
结果,而第二个给我1357053060000
。
我想念的是什么? 我尝试将时区设置为默认( cal.setTimeZone(TimeZone.getDefault());
),但是它没有用。
谢谢
您没有使用两个相等的日期时间。 你有:
2013-01-01 15:11:48
在您当地的时区(可能不是格林尼治标准时间) 1-1-2013 15:11 GMT
(格林尼治标准时间) 因此,这两个日期的时区与格林尼治标准时间之间的小时数有所不同。
您可以将第一个日期解析为GMT时区:
DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); // 2013-01-01 15:11:48
df.setTimeZone(TimeZone.getTimeZone("GMT"));
如果这样做,则两个日期时间都将获得相同的值( 1357053060000
)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.