1.特征
DateTimeOffset 含有相对utc的时区偏移量,如6/19/2008 7:00:00 AM +05:00;
DateTime 含有时区,如 6/19/2008 2:00:00 AM Utc
2.使用场景
例如:mysql数据库中的datetime字段没有时区概念 ,所以可存DateTimeOffset且时区偏移量为0的时间(相当于存UTC时间),取出来按当地时区还原即可
3.常用的DateTimeOffset 的构造
第一种:DateTimeOffset.Now (根据本地时区生成偏移量,如东八区为2022/3/21 14:58:29 +08:00)
第二种: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(baseTime));
或new DateTimeOffset(baseTime, TimeZoneInfo.FindSystemTimeZoneById("Central Standard Time").GetUtcOffset(baseTime))
4.DateTimeOffset转换为DateTime
(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