簡體   English   中英

將varchar轉換為Decimal Arithmetic溢出錯誤,將varchar轉換為數值類型的數據

[英]Convert varchar to Decimal Arithmetic overflow error converting varchar to data type numeric

請有人可以幫我這個簡單的SQL查詢

SELECT avg(CAST(NULLIF(Sim1SS,0.0) as DECIMAL)) as MTN ,
avg(CAST(NULLIF(Sim2SS,0.0) as DECIMAL)) as Vodacom

FROM [Networks].[dbo].[Device] 

我收到以下錯誤:

將varchar轉換為數值數據類型的算術溢出錯誤。

這是SS列的示例:

28,99
10,99
11,99
NULL
NULL
31,99
31,99
NULL

你有兩個問題。 首先,在字符串數據類型上使用NULLIF時,會將其隱式轉換為數字數據類型。 您已將0.0指定為第二個參數。 SQL Server不知道要選擇什么,它可能會選擇一個float或其他內容。 將字符串轉換為數字后應調用NULLIF

其次,您尚未為DECIMAL數據類型指定精度和小數位數。 根據MSDN ,DECIMAL數據類型的默認精度和小數位數為18,0。 如果未指定比例,數字將被截斷。

因此,正確的語法應為:

SELECT avg(NULLIF(CAST(Sim1SS as DECIMAL(18,2)), 0.00)) as MTN,
       avg(NULLIF(CAST(Sim2SS as DECIMAL(18,2)), 0.00)) as Vodacom
FROM [Networks].[dbo].[Device] 

順便說一句,如果您的十進制符號的區域設置不是句點( . ),那么您需要進行替換:

SELECT avg(NULLIF(CAST(REPLACE(Sim1SS, ',', '.') as DECIMAL(18,2)), 0.00)) as MTN,
       avg(NULLIF(CAST(REPLACE(Sim2SS, ',', '.') as DECIMAL(18,2)), 0.00)) as Vodacom
FROM [Networks].[dbo].[Device] 

如果您的數據未清理,則需要使用ISNUMERIC函數,如下所示:

SELECT avg(NULLIF(case when isnumeric(Sim1SS)=1 then CAST(REPLACE(Sim1SS, ',', '.') as DECIMAL(18,2)) end, 0.00)) as MTN,
       avg(NULLIF(case when isnumeric(Sim2SS)=1 then CAST(REPLACE(Sim2SS, ',', '.') as DECIMAL(18,2)) end, 0.00)) as Vodacom
FROM [Networks].[dbo].[Device] 

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM