简要咨询咨询QQ网站导航网站搜索手机站点联系我们设为首页加入收藏 

sql server 表交叉显示及实现方法

来源:易贤网   阅读:729 次  日期: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技术专栏

更多信息请查看数据库
点此处就本文及相关问题在本站进行非正式的简要咨询(便捷快速)】     【点此处查询各地各类考试咨询QQ号码及交流群
上一篇:sql server 代理错误日志知多少
下一篇:sql server 2005使用的网络协议
易贤网手机网站地址:sql server 表交叉显示及实现方法
由于各方面情况的不断调整与变化,易贤网提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!