最近我正在使用sql Server中的ISNUMERIC,当我遇到一个问题,导致找到这段代码.
SELECT ISNUMERIC('.')@H_404_3@这返回1,如在true中,不应该返回0为false吗?
解决方法
见
IsNumeric() Broken? Only up to a point.
SELECT CAST('.' AS MONEY)@H_404_3@返回0.00(尽管int和float的转换失败)
ISNUMERIC只是检查该值可以转换为通常无用的任何一个数字数据类型.通常你想知道是否可以转换为特定的类型.
Additionally it doesn’t even seem to do that task correctly for all possible inputs..ISNUMERIC(”)返回0,尽管成功地将int和money进行了转换.相反,ISNUMERIC(N’8′)返回1,但不会成功地投射到我尝试的任何东西.
一些有用的帮助函数在这里是IsNumeric,IsInt,IsNumber.
sql Server 2012引入了
TRY_PARSE
和TRY_CONVERT
,大大有助于此.