我对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,不管夏令时是否发生了变化
我想不出我是第一个遇到这个问题的人。别人怎么做才能解决这个问题? (或者我的事实是错误的吗?)
答案 0 :(得分:6)
不,它不会添加当前偏移量 - 它会在该日期添加偏移量仍为-6。所以它应该仍然显示在上午10:15,因为它知道所涉及的日期,因此在该日期生效的时区规则。
顺便说一句,您可能希望单独存储简单的UTC时间和时区标识符。如果您要存储时区,那么使用DateTimeOffset
对于UTC日期/时间不会特别有用。 (另一方面,更明确的是 代表一个瞬间 - DateTime
是一种非常混乱的类型,它不会让你轻易表达你想要表达的内容。 )
当然,我个人鼓励你看看Noda Time,我认为这是一个比内置的API更清晰的日期/时间API ...但是还没有准备好生产用途。 (我们到了那里......)