MsSQL   发布时间:2022-05-16  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了SQL Server 2005将VARCHAR转换为INT,但默认为无效类型大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我在表中有一个varchar(100)列,它包含整数(作为字符串)和非整数字符串的混合.例如.
| dimension varchar(100) |
| '5'                    |
| '17'                   |
| '3'                    |
| 'Pyramids'             |
| 'Western Bypass'       |
| '15'                   |

我怎样才能写一个表达式,例如总结所有有效整数的值?如果我尝试:

-- should return 5 + 17 + 3 + 15 = 40
SELECT
    SUM( CONVERT( INT,dimension ) )
FROM
    mytable

将varchar值’Pyramids’转换为数据类型int时,我会收到转换失败.错误.

是否有我可以在我的表达式中使用的测试,就像ISNULL()函数一样,如果字段不是数字,它允许我指定默认值?

解决方法

试试这个:
SELECT
    SUM(CASE ISNUMERIC(dimension) 
           WHEN 1 THEN CONVERT( INT,dimension ) 
           ELSE 0  
        END)
FROM
    mytable

CASE应检查维度是否为数字 – 如果是,则返回该值.如果它不是数字,则返回默认值(此处:0)

您是否需要经常查询,还可以向表中添加一个持久的计算列,该列封装此计算并存储该值.这样,当求和等等时,你并不总是重新计算这个值:

ALTER TABLE mytable
  ADD NumericValue AS CASE ISNUMERIC(dimension) 
      WHEN 1 THEN CONVERT( INT,dimension ) ELSE 0 END PERSISTED

现在,您可以选择维度,numericvalue FROM mytable并获取这两个值,而无需执行任何计算.

大佬总结

以上是大佬教程为你收集整理的SQL Server 2005将VARCHAR转换为INT,但默认为无效类型全部内容,希望文章能够帮你解决SQL Server 2005将VARCHAR转换为INT,但默认为无效类型所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: