执行以下查询后,我将得到一个错误
向“datetime”列添加值会导致溢出。
我不知道为什么会发生这样的事情,因为它已经顺利地运作了几个星期。我只是尝试在这里添加日期,并将它们与开始日期和结束日期与between子句进行比较。
DATEADD(day, -1 , DATEADD(mm, DATEDIFF(mm,0,posting_date),0)) BETWEEN start_date and end_date发布于 2012-02-02 20:29:59
我可以用以下方法复制错误:
declare @posting_date datetime
set @posting_date = '1/1/1753'
select DATEADD(day, -1 , DATEADD(mm, DATEDIFF(mm,0,@posting_date),0)) 运行它后出错:
Msg 517、级别16、状态1、第3行向“datetime”列添加值会导致溢出。
基本上,上述情况下的posting_date是server所允许的最小日期时间值。如果您然后尝试从其中减去1天,那么它就进入了溢出状态。
我的猜测是,您有一个数据池,它被设置为SQL Server's minimum date value。
发布于 2012-02-02 20:28:14
根据MSDN:
日期参数不能增加到其数据类型范围以外的值。在下列语句中,添加到日期值的数字值超过日期数据类型的范围。返回以下错误消息:“向'datetime‘列添加值会导致溢出。
列的数据类型以及start_date和end_date的范围是什么?
https://stackoverflow.com/questions/9119403
复制相似问题