如何获取单行数据

时间:2014-02-20 18:36:13

标签: tsql

我有一个名为RUGS的表,其中包含以下数据。如何编写TSQl查询以获取输出中显示的数据。我对unPIVOT不熟悉

`cono ARtype days Revenue PPD

140 MCD 5 1000 500

140 MRA 6 2000 600

140 MRA 7 3000 700

141 MCD 1 5000 100

141 MRA 2 6000 200

141 MRA 3 7000 300`

结果

140 MCD 5 1000 500 MRA 6 2000 600 MRA 7 3000 700

141 MCD 1 5000 100 MRA 2 6000 200 MRA 3 7000 300

1 个答案:

答案 0 :(得分:3)

鉴于每个cono将有3条记录(如评论中所述),cte row_number可与case语句一起使用。

如果任何记录少于三个,您将在结果中看到空白和零。任何超过三个的人都不会代表所有记录。

以下是@RUGS作为表变量的示例:

declare @RUGS table (cono int, ARType char(3), [days] int, Revenue int, PPD int)

insert into @RUGS VALUES
(140,'MCD',5,1000,500)
,(140,'MRA',6,2000,600)
,(140,'MRA',7,3000,700)
,(141,'MCD',1,5000,100)
,(141,'MRA',2,6000,200)
,(141,'MRA',3,7000,300);

with cte as 
(
    select row_number() over(partition by cono order by (select 1)) as rn, * from @RUGS
)

select cono, 
    max(case when rn = 1 then ARType else '' end) as ARType1, 
    max(case when rn = 1 then days else '' end) as days1, 
    max(case when rn = 1 then Revenue else '' end) as Revenue1, 
    max(case when rn = 1 then PPD else '' end) as PPD1,
    max(case when rn = 2 then ARType else '' end) as ARType2, 
    max(case when rn = 2 then days else '' end) as days2, 
    max(case when rn = 2 then Revenue else '' end) as Revenue2, 
    max(case when rn = 2 then PPD else '' end) as PPD2,
    max(case when rn = 3 then ARType else '' end) as ARType3, 
    max(case when rn = 3 then days else '' end) as days3, 
    max(case when rn = 3 then Revenue else '' end) as Revenue3, 
    max(case when rn = 3 then PPD else '' end) as PPD3      
from cte group by cono