首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >不允许将数据类型日期显式转换为bigint。

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

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

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

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

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

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2017-05-30 20:46:30

还有另一种选择。这甚至会为你翻转标志。

示例

代码语言:javascript
运行
复制
Declare @YourTable table (StartDate date)
Insert Into @YourTable values ('2017-05-30')

Select DateDiff(DAY,StartDate,-1)
 From @YourTable

返回

代码语言:javascript
运行
复制
-42884
票数 2
EN

Stack Overflow用户

发布于 2017-05-30 20:41:16

您可以将开始日期作为cast作为datetime进行转换。

代码语言:javascript
运行
复制
CONVERT(BIGINT,CAST(ev.StartDate as DATETIME)) * -1
票数 5
EN

Stack Overflow用户

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

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

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

一个简单的方法是:

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

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

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

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

https://stackoverflow.com/questions/44271515

复制
相关文章

相似问题

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