在SQL server中使用cast转换字段类型并规避空值

就是分类汇总表中的数据,使用sum函数。但是数据是字符型的,需要在计算时,转换为数值类型numeric。使用cast函数时,因为有空值,导致无法成功执行,就要用到isnumeric函数,但是我不知道怎么在sum函数里套一个cast,再套一个isnumeric

有两种方式:
1、先判断是numeric的才进行cast转换,否则就直接使用0

select sum(case when isnumeric(字段名) then cast(字段名 as numeric) else 0 end) from 分类汇总表

2、直接对所有记录进行cast,如果记录不是numeric,就用0来做转换

select sum(cast(case when isnumeric(字段名) then 字段名  else '0' end as numeric)) from 分类汇总表

望采纳,谢谢!