我的JS日期时间戳以全毫秒保真度1/1000记录。 (使用SQL我明白精度是1/300)
我一直在使用.NET System.DateTime struct
,而不看到SQL存储的毫秒数。
...
[ResponseTimeStamp] DATETIME NOT NULL,
...
用c#
//TimeCompleted is epoc
DateTime dtDateTime = new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc);
qr.ResponseTimeStamp = dtDateTime.AddMilliseconds(item.Responses.TimeCompleted);
我现在正在尝试将System.Data.SqlTypes.SqlDateTime
与
SqlDateTime dtDateTime = new SqlDateTime(1970, 1, 1, 0, 0, 0, 0);
qr.ResponseTimeStamp = SqlDateTime.Add(dtDateTime, item.Responses.TimeCompleted);
问题是该方法抛出异常:
“message”:“最佳重载方法匹配 “System.Data.SqlTypes.SqlDateTime.Add(System.Data.SqlTypes.SqlDateTime, System.TimeSpan)'
我尝试过从epoc
转换为TimeSpan
,但签名需要我创建的TimeSpan,但仍然会抛出异常。
TimeSpan newSpan = new TimeSpan(0, 0, 0, 0, item.Responses.TimeCompleted);
最佳重载方法匹配 “System.Data.SqlTypes.SqlDateTime.Add(System.Data.SqlTypes.SqlDateTime, System.TimeSpan)'有一些无效的参数
答案 0 :(得分:2)
如果您需要将时间存储到毫秒,那么您应该使用datetime2或datetimeoffset来获取数据。
这两种类型都允许精确到毫秒级,而不像DateTime那样只有3毫秒的分辨率。