行列转换:
姓名 课程 分数
张三 语文 74
张三 数学 83
张三 物理 93
李四 语文 74
李四 数学 84
李四 物理 94
想变成(得到如下结果):
姓名 语文 数学 物理
---- ---- ---- ----
李四 74 84 94
张三 74 83 93
create table sc(姓名 varchar(10),课程 varchar(10),分数 float)
insert into sc
select '张三','语文',74
union
select '张三','数学',83
union
select '张三','物理',93
union
select '李四','语文',74
union
select '李四','数学',84
union
select '李四','物理',94
方法1:
declare @sql varchar(max)
set @sql='select '
select @sql=@sql+', max(case when 课程='''+课程+''' then 分数 else '''' end)['+课程+']' from (select distinct 课程 from sc)t
set @sql = STUFF(@sql,8,1,'')
print @sql
set @sql=@sql+' ,姓名 from sc group by 姓名'
exec(@sql)
方法2:
select 姓名,数学,物理,语文 from sc pivot( max(分数) for 课程 in(数学,物理,语文))t
方法3:
declare @sql varchar(8000)
select @sql = isnull(@sql + '],[' , '') + 课程 from sc group by 课程
print @sql
set @sql = '[' + @sql + ']'
exec ('select * from (select * from tb) a pivot (max(分数) for 课程 in (' + @sql + ')) b')
行列置换:
姓名 语文 数学 物理
----------------------------------
张三 80 90 85
李四 85 92 82
要求使用T-SQL语言实现以下结果:
课程 张三 李四
----------------------
语文 80 85
数学 90 92
物理 85 82
drop table sc
create table sc(姓名 varchar(10),语文 int,数学 int,物理 int)
insert into sc
select '张三',80,90,85
union all
select '李四',85,92,82
select * from sc
-------------这个过程不就是unpivot,有时间再补充?
select * into sc1 from(
select 姓名,'语文' 课程,语文 分数 from sc
union
select 姓名,'数学' 课程,数学 from sc
union
select 姓名,'物理' 课程,物理 from sc
)t
补充unpivot,和上面操作时同样的效果
select 姓名,课程,分数 into #sc1 from sc unpivot(分数 for 课程 in([语文],[数学],[物理]))a
declare @sql varchar(8000)
set @sql='select '
select @sql=@sql+', max(case when 姓名='''+姓名+''' then 分数 else ''''end)['+姓名+']' from (select distinct 姓名 from
sc1)t
set @sql=stuff(@sql,8,1,'')
set @sql=@sql+' ,课程 from sc1 group by 课程'
print @sql
exec(@sql)
补充动态pivot和unpiot
--------------pivot
declare @sql varchar(8000)
select @sql = isnull(@sql + '],[' , '') + 课程 from tb group by 课程
print @sql
set @sql = '[' + @sql + ']'
exec ('select * from (select * from tb) a pivot (max(分数) for 课程 in (' + @sql + ')) b')
--------------unpivot
declare @sql varchar(8000)
select @sql = isnull(@sql + '],[' , '') + name from syscolumns where id=OBJECT_ID('tb') and colorder>1
set @sql = '[' + @sql + ']'
exec ('select 姓名,课程,分数 from (select * from tbtb) a unpivot (分数 for 课程 in (' + @sql + ')) b')