加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql – 为什么ISNUMERIC(‘.’)返回1?

发布时间:2020-12-12 08:41:49 所属栏目:MsSql教程 来源:网络整理
导读:最近我正在使用SQL Server中的ISNUMERIC,当我遇到一个问题,导致找到这段代码. SELECT ISNUMERIC('.') 这返回1,如在true中,不应该返回0为false吗? 解决方法 见 IsNumeric() Broken? Only up to a point. SELECT CAST('.' AS MONEY) 返回0.00(尽管int和float的
最近我正在使用SQL Server中的ISNUMERIC,当我遇到一个问题,导致找到这段代码.
SELECT ISNUMERIC('.')

这返回1,如在true中,不应该返回0为false吗?

解决方法

见 IsNumeric() Broken? Only up to a point.
SELECT CAST('.' AS MONEY)

返回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_PARSETRY_CONVERT,大大有助于此.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读