zqh0922
zqh0922
2016-01-22 12:36

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

2
  • textbox
  • 数据库
  • sql

在用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)来改,因为不知道字段值是多少。

  • 点赞
  • 回答
  • 收藏
  • 复制链接分享

4条回答

为你推荐