格力空调故障代码e0:Varchar到数字转换-CLR或'e0'

关于格力空调故障代码e0的问题,在e0 value中经常遇到, 我想将数据从 Varchar 列转换为 Numeric 数据类型-所以在转换之前,我调用 ISNUMERIC 函数来检查数据是否为数字,如果是,则将其转换为数字数据类型。

我想将数据从 Varchar 列转换为 Numeric 数据类型-
所以在转换之前,我调用 ISNUMERIC 函数来检查数据是否为数字,如果是,则将其转换为数字数据类型。

- IsNumeric(x) returns true - when varchar value has both comma and a tab character (Char(9)), 
- IsNumeric(x) returns false - when varchar value has only tab character and no comma

它在的 SQL 的帮助下解释-

DECLARE @propValue AS VARCHAR(50)
SET @propValue = '1,592 ' -- contains comma + tab (Char(9))
SELECT ISNUMERIC(@propValue)  -- Returns 1 
--If ISNUMERIC func returns true for this value, lets convert this Varchar value to Numeric
SELECT CAST(@propValue AS Numeric(19, 4)) -- :-( Error converting data type varchar to numeric.

我用 Google 搜索并找到了解决这个问题的各种解决方案-

--Solution 1: use 'e0'
SELECT ISNUMERIC(@propValue + 'e0')  -- Returns 0
--Solution 2: remove comma before calling IsNumeric()
SELECT ISNUMERIC(REPLACE(@propValue, ',', ''))  -- Returns 0
--Solution 3
--Call CLR function to p Varchar value

在上述情况下推荐的解决方案是什么,为什么?
另外,如果有人可以解释为什么 IsNumeric(x)返回 false-当 varchar 值只有制表符,没有逗号?

非常感谢。

1

请记住,ISNUMERIC() = 1并不意味着“可以转换为每个数字类型”,而是“可以转换为至少一个数字类型”。这出现了很多值可以转换为至少一个数字类型,但不是你想要的。一个更基本的例子:

IF ISNUMERIC(256) = 1
  SELECT CONVERT(TINYINT, 256);

如果您有已知违规的字符串(如制表符),那么为什么不也替换制表符?

这工作,但它是相当丑陋的:

DECLARE @x TABLE (propValue VARCHAR(50));
INSERT @x SELECT '1,592' + CHAR(9)
UNION ALL SELECT '55' + CHAR(9) + '32'
UNION ALL SELECT CHAR(9) + '7,452.32    '
UNION ALL SELECT 'foo'
UNION ALL SELECT '74';
SELECT CONVERT(NUMERIC(19,4), 
LTRIM(RTRIM(REPLACE(REPLACE(propValue, CHAR(9), ''), ',', '')))
)
FROM @x
WHERE ISNUMERIC(LTRIM(RTRIM(REPLACE(REPLACE(propValue, 
  CHAR(9), ''), ',', ''))) + 'e0') = 1;

虽然不适用于您的确切问题,但我在 10 年前写了一个常见问题:http://classicasp.aspfaq.com/general/what-is-wrong-with-isnumeric.html

-1
ISNUMERIC(RTRIM(LTRIM(x))) = 1

本站系公益性非盈利分享网址,本文来自用户投稿,不代表码文网立场,如若转载,请注明出处

(16)
C罗双国籍:在 C++中实现双sqrt(双x)
上一篇
Mysql分页:PHP和 MySQL分页
下一篇

相关推荐

  • cvt和自动挡哪个好提升驾驶体验的最佳选择

    CVT(可变转换器)是一种由传动带及传动轮组成的无级变速器,它可以在没有传动档位的情况下,根据驾驶者的驾驶习惯,自动调整传动轮之间的转速比,从而实现无级变速。自动挡是指车辆自动变速箱,它使用液力传动来实现变速,可以自动适应车辆的行驶状态,减少司机的疲劳,提高行车的舒适性。…

    2023-06-08 07:42:19
    0 16 68
  • cv一叶扁舟和清影轩阳:漫游在一叶扁舟和清影轩阳之间

    cv一叶扁舟是一款开源的计算机视觉库,用于图像处理、计算机视觉等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。清影轩阳是一款开源的计算机视觉框架,用于图像处理、目标检测、分类等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。…

    2023-08-05 07:06:20
    0 41 41
  • css设置滚动条宽度设置:This is a title

    CSS设置滚动条宽度的方法:使用CSS3的。-webkit-属性:…

    2023-06-06 10:53:01
    0 72 46
  • xl和xe汽车cvt:探索XL和XE汽车的CVT技术优势

    XL和XE汽车CVT是一种变速器,它使用液力变矩器代替传统的机械变速器,以达到更高的效率。它的工作原理是,当发动机输出功率时,液力变矩器就会将这些功率转换为液压能量,然后将能量传递到变速器的输出轴上,从而实现变速。…

    2023-04-09 00:41:04
    0 20 87
  • cordon bleu是什么意思:法式炸鸡卷——Cordon Bleu的经典之作

    Cordon Bleu是一种烹饪技术,其中肉片被置于奶酪和火腿之间,然后用面包屑裹上,最后煎炸或烤熟。这种技术通常用于制作鸡肉,但也可以用于制作其他类型的肉类,如牛肉或猪肉。…

    2024-01-27 15:13:30
    0 19 61
  • countif 非空:非空单元格的计数

    Countif 非空是指计算某个单元格不为空的数量。代码如下:…

    2023-04-22 15:54:15
    0 54 98
  • java double保留一位小数:How to Round a Double to One Decimal Place in

    示例示例使用类可以轻松实现java double保留一位小数的功能,具体代码如下:// 创建对象…

    2023-05-14 07:40:03
    0 76 78
  • linux如何写c语言一个完整的指南

    示例示例在Linux系统中,可以使用C语言编写源代码文件,然后使用GCC编译器来编译源代码文件,生成可执行文件。下面是一个简单的C语言代码示例:…

    2023-05-16 02:02:45
    0 46 73

发表评论

登录 后才能评论

评论列表(72条)