sql server 表交叉显示及实现方法
来源: 阅读:732 次 日期:2014-12-10 11:45:48
温馨提示: 小编为您整理了“sql server 表交叉显示及实现方法”,方便广大网友查阅!

假设有张学生成绩表(t)如下:

name subject result

张三 语文73

张三 数学83

张三 物理93

李四 语文74

李四 数学84

李四 物理94

想变成

姓名 语文 数学 物理

张三 738393

李四 748494

代码

create table #t

(

name varchar(10) ,

subject varchar(10) ,

result int

)

insert into #t(name , subject , result) values('张三','语文','73')

insert into #t(name , subject , result) values('张三','数学','83')

insert into #t(name , subject , result) values('张三','物理','93')

insert into #t(name , subject , result) values('李四','语文','74')

insert into #t(name , subject , result) values('李四','数学','83')

insert into #t(name , subject , result) values('李四','物理','93')

declare @sql varchar(8000)

set @sql = 'select name as 姓名'

select @sql = @sql + ' , sum(case subject when ''' + subject + ''' then result end) [' + subject + ']'

from (select distinct subject from #t) as a

set @sql = @sql + ' from #t group by name'

exec(@sql)

drop table #t

--结果

姓名 数学 物理 语文

---------- ----------- ----------- -----------

李四 83 93 74

张三 83 93 73

如果上述两表互相换一下:即

姓名 语文 数学 物理

张三 738393

李四 748494

想变成

name subject result

张三 语文73

张三 数学83

张三 物理93

李四 语文74

李四 数学84

李四 物理94

代码

create table #t

(

姓名 varchar(10) ,

语文 int ,

数学 int ,

物理 int

)

insert into #t(姓名 , 语文 , 数学 , 物理) values('张三',73,83,93)

insert into #t(姓名 , 语文 , 数学 , 物理) values('李四',74,84,94)

select 姓名 as name,'语文' as subject,语文 as result from #t union

select 姓名 as name,'数学' as subject,数学 as result from #t union

select 姓名 as name,'物理' as subject,物理 as result from #t

order by 姓名 desc

drop table #t

name subject result

---------- ------- -----------

张三 数学 83

张三 物理 93

张三 语文 73

李四 数学 84

李四 物理 94

李四 语文 74

(所影响的行数为 6 行)

更多信息请查看IT技术专栏

更多信息请查看数据库
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map