首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >以毫秒为单位的JavaScript日期时间戳到SqlDateTime

以毫秒为单位的JavaScript日期时间戳到SqlDateTime
EN

Stack Overflow用户
提问于 2016-08-02 14:36:09
回答 1查看 254关注 0票数 1

我有JS的日期时间戳被记录的完全毫秒保真度1/1000。(使用SQL我理解精度为1/300)

我一直在使用.NET System.DateTime struct,而不是正在看到存储在SQL中的毫秒。

代码语言:javascript
复制
...   
 [ResponseTimeStamp] DATETIME         NOT NULL,
...

用c#

代码语言:javascript
复制
//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

代码语言:javascript
复制
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,但仍然抛出一个异常。

代码语言:javascript
复制
TimeSpan newSpan = new TimeSpan(0, 0, 0, 0, item.Responses.TimeCompleted);

'System.Data.SqlTypes.SqlDateTime.Add(System.Data.SqlTypes.SqlDateTime,System.TimeSpan的最佳重载方法匹配“有一些无效的参数

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-08-02 14:41:11

如果您需要将时间存储到毫秒以下,那么您应该对数据使用datetime2日期时间偏移

这两种类型都允许精度下降到毫秒以下,与DateTime不同,后者只有3毫秒的分辨率。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38723442

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档