SQL SERVER 多行转多列

 

--★转换结果如上图

 

 

-创建测试标

CREATE TABLE [成绩表](

[编号] [int]IDENTITY(1,1) NOT NULL,

[姓名] [varchar](50)NULL,

[语文] [numeric](5, 2)NULL,

[数学] [numeric](5, 2)NULL,

[英语] [numeric](5, 2)NULL

) ON [PRIMARY]

 

--插入数据(我的是 sqlserver2008 r2)

INSERT INTO 成绩表([姓名],[语文],[数学],[英语])

VALUES('道一',80,100,90.8),('老二',48,56,60),('张三',88,78,90),('李四',80,90,95),('王五',67,68,56),('刘六',77,68,80)

 

-- SELECT * FROM 成绩表

 

--固定转换 查询 (结果如上图)

 

declare @sql_1 varchar(8000)

select @sql_1=''

select @sql_1= @sql_1 + 'select [编号],[姓名],['+name+']AS ''成绩'','''+name+''' AS ''课程'' from 成绩表 union all '

from syscolumns where id=object_id('成绩表')  and CHARINDEX(name,'编号,姓名')=0

select @sql_1= @sql_1 + ' select distinctnull,null,null,null from 成绩表 ' 

--注意!多一行 selectdistinct null,null,null,null from 成绩表

print @sql_1

--execute(@sql_1)

declare @sql_2 varchar(8000)

select @sql_2='select [课程] '

select @sql_2=@sql_2 + ',SUM(case when [姓名] = '''+[姓名]+''' then 成绩 else 0end) '''+[姓名]+''' '

from 成绩表

select @sql_2=@sql_2 + ' from ( '+@sql_1 +')as tb where ISNULL([编号],'''')<>'''' group by [课程]'

print @sql_2

execute(@sql_2)

 

 

--再插入数据

INSERT INTO 成绩表([姓名],[语文],[数学],[英语])

VALUES('鬼七',67,68,56),('王八',77,68,80)

 

 

--再执行动态语句 (结果如下图),动态查询随表变化


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值