首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用nvarchar更新DATEADD?

用nvarchar更新DATEADD?
EN

Stack Overflow用户
提问于 2016-12-27 16:09:24
回答 2查看 454关注 0票数 0

我被一个有列的表困住了,更新被设置为nvarchar(255),null。不是我的手工作品,我不能改变它。我现在需要在计算中使用这个列。下面是我在一条语句中尽我所能做到的,但是我无法通过“不正确的语法.”在the语句之后出错。如果它遇到了一个问题,试图将其转换为INT,那么我希望它继续处理其余的记录,而不是使用整个查询。我想我可以添加一个额外的列INT,而不是null,并在此之前编写一个update语句来运行,但我担心我会遇到同样的问题。我更喜欢UI而不是SQL,有什么建议吗?它将在SQLServer2008R上运行。提前谢谢你

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

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-12-27 16:12:52

END语句中缺少CASE

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

代码语言:javascript
复制
  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]%'
票数 3
EN

Stack Overflow用户

发布于 2016-12-27 16:15:00

这样就更简单了。

代码语言:javascript
复制
UPDATE C
SET [ExpirationDate] = DATEADD(MONTH, CAST(c.Renewal AS INT), [ExpirationDate])
FROM dbo.MyTable C 
WHERE C.MyCondition = 'True'  
AND ISNUMERIC(c.Renewal) = 1
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41348425

复制
相关文章

相似问题

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