日期:2014-05-16  浏览次数:20640 次

求取数的脚本,不复杂,但是很难
本帖最后由 fox1033 于 2014-04-30 09:06:46 编辑
数据表格式如下:
姓名     科目1   科目2   科目3  科目4  科目5  成绩1  成绩2  成绩3  成绩4  成绩5
张三      物理                 英语                地理    66                   77                   45
李四                  物理     数学                历史                55       85                   76  
------------------------------------------------------------------------------------------------------------
求语句:求语句或方法能列出每个人的考试科目和考试成绩
注:1、学科名称 不固定在哪个科目下  例如 张三的物理在科目1  李四的物理在科目2
        2、有的科目为空,为空的不取,成绩对应科目,例如张三的 成绩1对应的是科目1,即物理成绩为66
-------------------------------------------------------------------------------------------------------------
最终结果:
张三:
物理    66
英语    77 
地理    45
李四:
物理    55
数学    85
历史    76

------解决方案--------------------
不动脑的做法是每次抽对应不为null的两列然后做union all
------解决方案--------------------
就用1楼的方法吧。

select 姓名, 科目1 科目, 成绩1 成绩 from 表 where 科目1<>''
union all
select 姓名, 科目2 科目, 成绩2 成绩 from 表 where 科目2<>''
union all
select 姓名, 科目3 科目, 成绩3 成绩 from 表 where 科目3<>''
union all
select 姓名, 科目4 科目, 成绩4 成绩 from 表 where 科目4<>''
union all
select 姓名, 科目5 科目, 成绩5 成绩 from 表 where 科目5<>''

------解决方案--------------------
目测需要使用union拼接

--> 测试数据: [ta]
if object_id('[ta]') is not null drop table [ta]
 go
 create table [ta] ([姓名] varchar(4),[科目1] varchar(4),[科目2] varchar(4),[科目3] varchar(4),[科目4] varchar(4),[科目5] varchar(4),[成绩1] int,[成绩2] int,[成绩3] int,[成绩4] int,[成绩5] int)
insert into [ta]
select '张三','物理',null,'英语',null,'地理',66,null,77,null,45 union all
select '李四',null,'物理','数学',null,'历史',null,55,85,null,76

select * from [ta]

select 姓名,科目1,成绩1
from ta
where 科目1 is not null
union 
select 姓名,科目2,成绩2
from ta
where 科目2 is not null
union 
select 姓名,科目3,成绩3
from ta
where 科目3 is not null
union 
select 姓名,科目4,成绩4