我正在尝试将0.0015乘以100,但由于以下错误而失败:
将nvarchar值'0.0015‘转换为数据类型int时转换失败。
Cast(([Rate]*100) AS NVARCHAR(10)) AS Rate发布于 2017-06-22 23:36:37
乘以非整数:
Cast(([Rate]*100.0) AS NVARCHAR(10)) AS Rate但是,这将使用由常量指定的位数的小数转换rate!非常奇怪的结果是:
select '0.26' * 100.0, '0.26' * 100.00第一列是30!第二个是26,不出所料。
或者使用显式类型转换:
Cast(cast([Rate] as decimal(18, 4)) * 100 AS NVARCHAR(10)) AS Rate或者,更好的做法是将数据类型更改为适当的数据类型:
alter t alter column rate decimal(18, 4); -- or whatever寓意是什么?使用适当的数据类型存储值。
编辑:
您的代码中可能存在有问题的值。使用try_convert()或try_cast()
try_convert(varchar(10), try_convert(decimal(18, 4), Rate) * 100) as Rate(我改用varchar(),因为数字通常不需要国家字符集。)
要查找有问题的值,请执行以下操作:
select rate
from t
where try_convert(decimal(18, 4), rate) is null;https://stackoverflow.com/questions/44703808
复制相似问题