DateTimeOffset 含有相对utc的时区偏移量;
DateTime 含有时区
例如:mysql数据库中的datetime字段没有时区概念 ,所以可存DateTimeOffset且时区偏移量为0的时间(相当于存UTC时间),取出来按当地时区还原即可
第一种:new DateTimeOffset(2008, 6, 18, 7, 0, 0, new TimeSpan(-5, 0, 0));
第二种:DateTime baseTime= new DateTime(2008, 6, 19, 7, 0, 0);
new DateTimeOffset(baseTime, TimeZoneInfo.Local.GetUtcOffset(sourceDate));
或new DateTimeOffset(baseTime, TimeZoneInfo.FindSystemTimeZoneById("Central Standard Time").GetUtcOffset(baseTime))
(1)DateTime dateTime=dateTimeOffset.DateTime;
这样转换dateTime为dateTimeOffset的数值,时区丢失,即dateTime.Kind为UnSpecified
DateTime dateTime=DateTime.SpecifyKind(dateTimeOffset,DateTimeKind.Local);
这样转换dateTime为dateTimeOffset的数值,时区为Local(当然也可指定其它时区)
(2)DateTime dateTime=dateTimeOffset.LocalTime;
根据本地时区换算为本地时间,且dateTime.Kind为Local
(3)DateTime dateTime=dateTimeOffset.UtcDateTime;
根据本地时区换算为utc时间(0时区),且dateTime.Kind为Utc