我被一个有列的表困住了,更新被设置为nvarchar(255),null。不是我的手工作品,我不能改变它。我现在需要在计算中使用这个列。下面是我在一条语句中尽我所能做到的,但是我无法通过“不正确的语法.”在the语句之后出错。如果它遇到了一个问题,试图将其转换为INT,那么我希望它继续处理其余的记录,而不是使用整个查询。我想我可以添加一个额外的列INT,而不是null,并在此之前编写一个update语句来运行,但我担心我会遇到同样的问题。我更喜欢UI而不是SQL,有什么建议吗?它将在SQLServer2008R上运行。提前谢谢你
UPDATE C
SET [ExpirationDate] = DATEADD(MONTH,
(CASE WHEN ISNUMERIC(C.Renewal)= 1
THEN CAST(C.Renewal AS INT)
ELSE 0)
, [ExpirationDate])
FROM dbo.MyTable C
WHERE C.MyCondition = 'True' 发布于 2016-12-27 16:12:52
在END语句中缺少CASE
UPDATE C
SET [ExpirationDate] = Dateadd(MONTH, ( CASE
WHEN Isnumeric(C.Renewal) = 1 THEN Cast(C.Renewal AS INT)
ELSE 0
END ), [ExpirationDate])
FROM dbo.MyTable C
WHERE C.MyCondition = 'True' 只使用numeric值过滤记录,并应用DATEADD函数而不是添加0月份
另外,ISNUMERIC也不是首选的。如果字符串可以转换为任何一个ints、数字/十进制、浮点数或货币,则ISNUMERIC返回1。https://connect.microsoft.com/SQLServer/feedback/details/302466/isnumeric-returns-true-for-and
UPDATE C
SET [ExpirationDate] = DATEADD(MONTH,CAST(C.Renewal AS INT), [ExpirationDate])
FROM dbo.MyTable C
WHERE C.MyCondition = 'True'
AND C.Renewal NOT LIKE '%[^0-9]%'发布于 2016-12-27 16:15:00
这样就更简单了。
UPDATE C
SET [ExpirationDate] = DATEADD(MONTH, CAST(c.Renewal AS INT), [ExpirationDate])
FROM dbo.MyTable C
WHERE C.MyCondition = 'True'
AND ISNUMERIC(c.Renewal) = 1https://stackoverflow.com/questions/41348425
复制相似问题