[英]Decimal Data in Varchar datatype - Arithmetic overflow error converting varchar to data type numeric
[英]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.