首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Sql转换失败

Sql转换失败
EN

Stack Overflow用户
提问于 2017-06-22 23:34:46
回答 1查看 60关注 0票数 0

我正在尝试将0.0015乘以100,但由于以下错误而失败:

将nvarchar值'0.0015‘转换为数据类型int时转换失败。

代码语言:javascript
复制
Cast(([Rate]*100) AS NVARCHAR(10)) AS Rate
EN

回答 1

Stack Overflow用户

发布于 2017-06-22 23:36:37

乘以非整数:

代码语言:javascript
复制
Cast(([Rate]*100.0) AS NVARCHAR(10)) AS Rate

但是,这将使用由常量指定的位数的小数转换rate!非常奇怪的结果是:

代码语言:javascript
复制
select '0.26' * 100.0, '0.26' * 100.00

第一列是30!第二个是26,不出所料。

或者使用显式类型转换:

代码语言:javascript
复制
Cast(cast([Rate] as decimal(18, 4)) * 100 AS NVARCHAR(10)) AS Rate

或者,更好的做法是将数据类型更改为适当的数据类型:

代码语言:javascript
复制
alter t alter column rate decimal(18, 4);  -- or whatever

寓意是什么?使用适当的数据类型存储值。

编辑:

您的代码中可能存在有问题的值。使用try_convert()try_cast()

代码语言:javascript
复制
try_convert(varchar(10), try_convert(decimal(18, 4), Rate) * 100) as Rate

(我改用varchar(),因为数字通常不需要国家字符集。)

要查找有问题的值,请执行以下操作:

代码语言:javascript
复制
select rate
from t
where try_convert(decimal(18, 4), rate) is null;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44703808

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档