[英]Sql query to convert nvarchar to int
我必须使用聚合函数查询列的总量。 列数据类型是NVARCHAR(MAX)。 如何将其转换为整数?
我试过这个:
SELECT SUM(CAST(amount AS INT)),
branch
FROM tblproducts
WHERE id = 4
GROUP BY branch
......但我得到了:
将nvarchar值'3600.00'转换为数据类型int时转换失败。
3600.00不是整数所以CAST通过浮动优先
sum(CAST(CAST(amount AS float) AS INT))
编辑:
为何漂浮?
除了gbn的答案,你还需要防范非数字案例:
sum(CASE WHEN ISNUMERIC(Amount)=1 THEN CAST(CAST(amount AS float) AS INT)END )
SELECT sum(Try_Parse(金额为Int使用'en-US')),分支FROM tblproducts
WHERE id = 4 GROUP BY分支
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.