sql行转列的3种方法

行转列的3种方法

  1. max(case when)

  2. pivot()

  3. 用存储过程行转列

准备数据

--创建表
create table Table_A
(
    商家 string,
    奶茶 string,
    价格 bigint
);
--插入数据
insert into Table_A(商家,奶茶,价格) values
('1点点','波霸奶茶',14),
('1点点','四季奶青',14),
('喜茶','波霸奶茶',21),
('CoCo','四季奶青',16);
--查询数据
select * from Table_A ;

行转列-方法1:max(case when)

select 
    商家,
    max(case when 奶茶='波霸奶茶' then 价格 end) as 波霸奶茶,
    max(case when 奶茶='四季奶青' then 价格 end) as 四季奶青
from Table_A group by 商家;

行转列-方法2:pivot()

select * from Table_A pivot(max(价格) for 奶茶 in (波霸奶茶,四季奶青)) a;
--我这边使用的sql不支持使用pivot(),此语句的正确性有待验证;

行转列-方法3:用存储过程

alter proc pro_test
@userImages varchar(200),
@奶茶 varchar(20),
@奶茶1 varchar(200),
@TableName varchar(50)
as
 declare @sql varchar(max)='select * from (select '+@userImages+' from'+@TableName+') tab
pivot
(
sum('+@奶茶+') for 奶茶('+@奶茶1+')
) pvt'
exec (@sql)
go
exec pro_test '商家,奶茶,价格',
'Table_A',
'奶茶',
'波霸奶茶,四季奶青'
;
--我这边使用的sql不支持使用存储过程,此语句的正确性有待验证;

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值