2 zqh0922 zqh0922 于 2016.01.22 20:36 提问

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

4个回答

jiuwohuge
jiuwohuge   2016.01.29 11:47
已采纳

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

caozhy
caozhy   Ds   Rxr 2016.01.22 20:53

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

zqh0922
zqh0922 回复caozhy: 我说了,不能用ISNULL,因为不知道有哪些课程名称,有可能是数学,语文,英语;也可能是数学,语文,英语,地理。
接近 2 年之前 回复
caozhy
caozhy   Ds   Rxr 2016.01.22 21:19

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

zqh0922
zqh0922 回复caozhy: 我想有没有方法在行列转换时,自动就把空值变为0了
接近 2 年之前 回复
enpterexpress
enpterexpress   2016.01.22 22:57

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

zqh0922
zqh0922 回复人帅屌大惹人爱: Isnull的话,需要知道字段名,但是我的课程是一直在变。也就是in (语文,数学,英语,地理,物理,化学)这个里面是在变的。我在C#里面的窗体textbox里面让老师可以设置需要导出的课程。其实我是知道课程的,从textbox里面可以知道。但是具体怎么写sql语句,从textbox里面得到的内容得到isnull语句?谢谢!
接近 2 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!