SQL 数据库中行转列,和列转行

本文介绍如何使用SQL语句将表从行数据转换为列数据,反之亦然。具体包括两个部分:一是行转列,即将季度销售额从独立记录转换为同一行的不同列;二是列转行,即将不同季度的销售额从同一行的不同列转换为独立记录。

行转列:

原始表:

  create table sales( Year   int,   Queryter   int, Resultes  int) 
 insert into sales values (2004,1,20)
 insert into sales values(2004,2,30)
 insert into sales values(2004,3,40)
 insert into sales values (2005,1,25)
 insert into sales values (2005,2,35)
 insert into sales values (2005,3,45)

要转化成的表的形式为:

create table sales (Year int,Q1 int ,Q2 int , Q3 int)

 insert  into sales values(2004,20,30,40)

insert into sales values(2005,25,35,45)

 

实现上面转化的SQL语句是:   

  select Year ,max(case when Queryter=1 then Resultes end) as Q1,

        max (case when Queryter=2 then Resultes end) as Q2,

        max(case when Queryter=3 then   Resultes end)as Q3

     from  sales group by Year

列转成行:

   原始表:

create table salesAgg(Year int,Q1 int ,Q2 int , Q3 int)

 insert  into salesAgg values(2004,20,30,40)

insert into salesAgg values(2005,25,35,45)

需要变成的显示表为:

create table salesAgg( Year   int,   Queryter   int, Resultes  int) 
 insert into sales values (2004,1,20)
 insert into sales values(2004,2,30)
 insert into sales values(2004,3,40)
 insert into sales values (2005,1,25)
 insert into sales values (2005,2,35)
 insert into sales values (2005,3,45)

 

需要使用的sql语句:  select * from (
                 select Year,Queryter='1',Resultes=Q1 from salesAgg
                  union all
                 select Year,Queryter='2',Resultes=Q2from salesAgg union all
                 select Year,Queryter='3',Resultes=Q3from salesAgg
) t
 order by Year,Queryter

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值