gpt4 book ai didi

SQL 错误 - varchar 到数字

转载 作者:行者123 更新时间:2023-12-04 21:51:24 25 4
gpt4 key购买 nike

我将一个平面文件导入到 SQL 数据库中,并将所有字段创建为 varchar(50)。我能够更改大多数字段的数据类型,但在权重字段中出错。 weight字段中的所有数据总长度都小于6个字符,并且可以是整数或小数。我都试过:

UPDATE MAWB
SET Weight = CAST(Weight AS decimal(12,2))

和:
ALTER TABLE MAWB
ALTER COLUMN [Weight] decimal(10,2)

我总是收到错误:将数据类型 varchar 转换为数字时出错。

我已经使用以下方法检查了所有字段是否都被视为数字:
SELECT COUNT(*)
FROM MAWB
WHERE ISNUMERIC(Weight) = 0

为了安全起见,我也尝试过 LTRIM 和 RTRIM,但是当我尝试更改字段时仍然出现错误。有谁知道还有什么可能导致此错误?

最佳答案

所以, ISNUMERIC() is far from perfect .对于 e 之类的值,它可以返回 true , $ , '€' 和 tab 以及许多其他你意想不到的。但是当然您不能将它们转换为每种数字类型( ISNUMERIC() 仅标识它可以转换为至少一种数字类型)。 LTRIM()RTRIM()不会有帮助,因为他们不会清除制表符和其他类似的字符。

要识别真正不是数字的行:

SELECT weight FROM dbo.table WHERE column NOT LIKE '%[^0-9.-]%';

或者你可以编写一个更复杂的标量函数,就像上面链接中的那个,它处理更多的边缘情况:
CREATE FUNCTION dbo.isReallyNumeric  
(
@num VARCHAR(64)
)
RETURNS BIT
BEGIN
IF LEFT(@num, 1) = '-'
SET @num = SUBSTRING(@num, 2, LEN(@num))

DECLARE @pos TINYINT

SET @pos = 1 + LEN(@num) - CHARINDEX('.', REVERSE(@num))

RETURN CASE
WHEN PATINDEX('%[^0-9.-]%', @num) = 0
AND @num NOT IN ('.', '-', '+', '^')
AND LEN(@num)>0
AND @num NOT LIKE '%-%'
AND
(
((@pos = LEN(@num)+1)
OR @pos = CHARINDEX('.', @num))
)
THEN
1
ELSE
0
END
END
GO

一旦您确定了这些行并修复了数据,请也修复表格。

关于SQL 错误 - varchar 到数字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18156347/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com