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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值