sql 行列转换时,空值如何设置成0

在用Sql静态方法进行行列转换时,数据库存在的空值如何处理?我想空值变为0.
create table tb(姓名 varchar(10) , 学号 varchar(10), 课程 varchar(10) , 分数 int)
insert into tb values('张三' ,'123456', '语文' , 74)
insert into tb values('张三' ,'123456', '数学' , 83)
insert into tb values('张三' , '123459','物理' , 93)
insert into tb values('李四' , '123457','语文' , 74)
insert into tb values('李四' , '123457','数学' , 84)
insert into tb values('李四' , '123457','物理' , 94)
insert into tb values('李四' , '123458','语文' , 74)
insert into tb values('李四' , '123458','数学' , 84)
insert into tb values('李四' , '123458','地理' , 94)
go

select m.* , n.总分
from(select * from (select * from tb) a pivot (max(分数) for 课程 in (语文,数学,地理,物理,几何,生物,化学)) b) m,
(select 学号 , sum(分数) AS 总分 from tb group by 学号) n
where m.学号= n.学号
go
因为生成这个报表的时候,我想让使用者可以设置,即“语文,数学,地理,物理,几何,生物,化学”,可以在TextBox中设置,我已经实现了。但是在行列转换后,会出现很多空值,在后续的处理,如求取单科的平均成绩时,空值就不会参与计算,所以需要将空值变为0.因为课程可能会变的原因“语文,数学,地理,物理,几何,生物,化学”可能会改变,因此不能用ISNULL(字段值,0)来改,因为不知道字段值是多少。

不行加个临时字段,弄个触发器。专门用来生成报表使用,null字段直接保存为0

再select一次,
(select isnull(字段名),0) as 字段名

放入临时表,用下面的方法得到列名
http://www.cnblogs.com/yansheng/archive/2010/03/30/1700755.html

用isnull函数
isnull(<字段名>,0)