用于将nvarchar转换为int的SQL查询

Sim*_*dri 17 sql t-sql sql-server

我必须使用聚合函数查询列的总量.列数据类型是NVARCHAR(MAX).如何将其转换为整数?

我试过这个:

  SELECT SUM(CAST(amount AS INT)),
         branch 
    FROM tblproducts  
   WHERE id = 4
GROUP BY branch
Run Code Online (Sandbox Code Playgroud)

......但我得到了:

将nvarchar值'3600.00'转换为数据类型int时转换失败.

gbn*_*gbn 30

3600.00不是整数所以CAST通过浮动优先

sum(CAST(CAST(amount AS float) AS INT))
Run Code Online (Sandbox Code Playgroud)

编辑:

为何漂浮?

  • 不知道所有行的精度或比例:浮动也许是较小的邪恶
  • 对于float,空字符串将转换为零,在十进制时失败
  • float接受5E-02之类的东西,十进制失败


A-K*_*A-K 8

除了gbn的答案,你还需要防范非数字案例:

sum(CASE WHEN ISNUMERIC(Amount)=1 THEN CAST(CAST(amount AS float) AS INT)END ) 
Run Code Online (Sandbox Code Playgroud)