SQL Server 表交叉显示及实现方法
来源: 阅读:624 次 日期:2014-11-03 12:17:36
温馨提示: 小编为您整理了“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