发布
社区首页 >问答首页 >不允许将数据类型日期显式转换为bigint。

不允许将数据类型日期显式转换为bigint。
EN

Stack Overflow用户
提问于 2017-05-30 20:39:07
回答 4查看 8.5K关注 0票数 1

这曾经适用于列类型的DATEIME,但现在不适用于DATE

代码语言:javascript
代码运行次数:0
复制
CONVERT(BIGINT,ev.StartDate) * -1

是否存在从BIGINT列中获取DATE值的问题?

EN

Stack Overflow用户

发布于 2017-05-30 20:47:24

首先,Server中的日期按1900年起的天数计算。一个大整数在大约21亿的时候就开始有用了。这相当于一年,约580万人。你真的有那么大的约会吗?

当然,不允许对int进行强制转换。您可以转换datetime值。。。但还有其他方法吗?

一个简单的方法是:

代码语言:javascript
代码运行次数:0
复制
select 1 + datediff(day, 0, datecol)

需要"+ 1“,因此该值与实际转换相匹配。(您可以使用"-1“代替"0”。)

或者,您可能需要以秒或毫秒为单位的Unix时间。为此:

代码语言:javascript
代码运行次数:0
复制
select datediff_big(ms, '1970-01-01', datecol)
票数 2
EN
查看全部 4 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44271515

复制
相关文章

相似问题

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