为什么“0D0”在SQL Server 2008中被视为数字?
发布时间:2020-05-24 09:56:02 所属栏目:MsSql 来源:互联网
导读:知道为什么ISNUMERIC(‘0D0’)= 1在SQL Server 2008中为TRUE? 我正在验证来自另一个系统的ID号,它有时包含我们不想带来的字母,但这种组合使代码跳闸(它认为数字的特定ID是“005406257D6”).下游我们正在做CONVERT(BIGINT,@ val),当它找到这些“D”值时显然会
|
知道为什么ISNUMERIC(‘0D0’)= 1在SQL Server 2008中为TRUE? 我正在验证来自另一个系统的ID号,它有时包含我们不想带来的字母,但这种组合使代码跳闸(它认为数字的特定ID是“005406257D6”).下游我们正在做CONVERT(BIGINT,@ val),当它找到这些“D”值时显然会窒息. 我打的是什么特例,我该怎么说呢? 解决方法基本上,IsNumeric是无用的 – 它验证的是字符串可以转换为任何数字类型.在这种情况下,“0D0”可以转换为浮点数. (我不记得原因,但有效地“D”是“E”的同义词,并且意味着它是科学记数法):select CONVERT(float,'2D3')
如果你想验证它只是数字,那么不像’%[^ 0-9]%’这样的@val会是一个更好的测试.您还可以通过添加长度检查来进一步改进. (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
