夏令时更改后显示DateTimeOffset

时间:2011-07-20 22:43:58

标签: c# .net datetime .net-4.0 datetimeoffset

我对DateTimeOffset和夏令时有疑问。为了解释我的问题,我们假设现在的日期和时间是:

11/6/2010  10:15:00 AM 

如果我运行此代码:

DateTimeOffset myTime = DateTimeOffset.Now;
Console.WriteLine("Local time: " + myTime.ToLocalTime().DateTime);

然后我得到了这个结果:

  

当地时间:11/6/2010 10:15:00 AM

意味着事件发生在早上10:15(我的时区是Mountain Daylight Time(-6 offset))。

然后,我将此DateTimeOffset保存到我的SQL Server 2008 db(作为DateTimeOffset)。第二天我想把它显示给用户。但现在夏令时已经到期。

如果我使用保存的off值运行上述WriteLine(从前一天开始)会显示什么?

数据库中存储的偏移量为-6。但是现在夏令时结束了,目前的偏差是-7。据我了解documentation,它首先将我的时间转换为UTC时间(所以它需要上午10:15并增加6小时(下午4:15)。然后它将减去当地时间的当前偏移量(下午4:15 - 7 = 9:15 AM)。

所以,如果我的数学是正确的,那么现在当我展示我的活动时,它会显示它发生在上午9:15而不是上午10:15。

这不好。我想存储时区信息,但我需要时间在同一时区保持静态。 (意思是如果事件发生在犹他州的上午10:15,那么下次我看它(在犹他州),我需要看到它是在上午10:15,不管夏令时是否发生了变化

我想不出我是第一个遇到这个问题的人。别人怎么做才能解决这个问题? (或者我的事实是错误的吗?)

1 个答案:

答案 0 :(得分:6)

不,它不会添加当前偏移量 - 它会在该日期添加偏移量仍为-6。所以它应该仍然显示在上午10:15,因为它知道所涉及的日期,因此在该日期生效的时区规则。

顺便说一句,您可能希望单独存储简单的UTC时间和时区标识符。如果您要存储时区,那么使用DateTimeOffset对于UTC日期/时间不会特别有用。 (另一方面,更明确的是 代表一个瞬间 - DateTime是一种非常混乱的类型,它不会让你轻易表达你想要表达的内容。 )

当然,我个人鼓励你看看Noda Time,我认为这是一个比内置的API更清晰的日期/时间API ...但是还没有准备好生产用途。 (我们到了那里......)