SQL Server中行列转换

系统 1622 0

drop table #Tmp --删除临时表#Tmp
create table #Tmp --创建临时表#Tmp
(
ID int not null, --创建列ID,并且每次新增一条记录就会加1
Temp_NAME varchar(50),
AMOUNT money
);

insert into #tmp
Select 1 ,'A', 2 union all
Select 2 ,'A', 3 union all
Select 3 ,'B', 20 union all
Select 4 ,'C', 6 union all
Select 5 ,'C', 19 

--1 原始的
select * from #tmp

--2 筛选的
select Temp_NAME,AMOUNT from #tmp a
WHERE ID=(SELECT max(ID) FROM #tmp WHERE Temp_NAME=a.Temp_NAME)

--3 行转列的
Select
max(case Temp_NAME when 'A' then AMOUNT else 0 end) [A] ,
max(case Temp_NAME when 'B' then AMOUNT else 0 end) [B] ,
max(case Temp_NAME when 'C' then AMOUNT else 0 end) [C]
from (select Temp_NAME,AMOUNT from #tmp a
WHERE ID=(SELECT max(ID) FROM #tmp WHERE Temp_NAME=a.Temp_NAME)
) As T group by AMOUNT

---4 pivot 的
select * from
(select Temp_NAME,AMOUNT from #tmp a
WHERE ID=(SELECT max(ID) FROM #tmp WHERE Temp_NAME=a.Temp_NAME)
) As T pivot(max(AMOUNT)for Temp_NAME in(A,B,C)) a

SQL Server中行列转换


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论