JavaScript日期时间戳到SqlDateTime,带有毫秒

时间:2016-08-02 14:36:10

标签: c# datetime sqldatetime

我的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)'有一些无效的参数

1 个答案:

答案 0 :(得分:2)

如果您需要将时间存储到毫秒,那么您应该使用datetime2datetimeoffset来获取数据。

这两种类型都允许精确到毫秒级,而不像DateTime那样只有3毫秒的分辨率。