Reputation: 323
I am trying to JOIN two tables and use CASE statements but, I'm not getting the results I want.
Here is my existing code:
SELECT i.[ProviderID], l.FacilityName,
CASE WHEN [StepID] = 1 THEN 'Step0.5' END AS 'Step0.5',
CASE WHEN [StepID] = 2 THEN 'StepI' END AS 'StepI',
CASE WHEN [StepID] = 4 THEN 'StepI.D' END AS 'StepI.D',
CASE WHEN [StepID] = 5 THEN 'StepII.1' END AS 'StepII.1',
CASE WHEN [StepID] = 6 THEN 'StepII.5' END AS 'StepII.5',
CASE WHEN [StepID] = 7 THEN 'StepII.D' END AS 'StepII.D',
CASE WHEN [StepID] = 8 THEN 'StepIII.1' END AS 'StepIII.1'
FROM RD.dbo.vwProvider as l
INNER JOIN [RD].[dbo].[vwSteps] i
ON l.ProviderID = i.ProviderID
Group by i.[ProviderID], l.FacilityName, [StepID]
ORDER BY FacilityName
Here are my current results:
ProviderID FacilityName Step0.5 StepI StepI.D StepII.1 StepII.5 StepII.D StepIII.1
4 This Is Us Step0.5 NULL NULL NULL NULL NULL NULL
4 This Is Us NULL NULL StepI.D NULL NULL NULL NULL
6 Almost NULL NULL NULL StepII.1 NULL NULL NULL
6 Almost NULL NULL NULL NULL NULL StepII.D NULL
6 Almost NULL StepI NULL NULL NULL NULL NULL
Here are the results I am looking for:
ProviderID FacilityName Step0.5 StepI StepI.D StepII.1 StepII.5 StepII.D StepIII.1
4 This Is Us Step0.5 NULL StepI.D NULL NULL NULL NULL
6 Almost NULL StepI NULL StepII.1 NULL StepII.D NULL
Upvotes: 0
Views: 769
Reputation: 38325
Aggregate using MAX()
or MIN()
, and it seems you do not need StepID
in GROUP BY
:
SELECT i.[ProviderID], l.FacilityName,
max(CASE WHEN [StepID] = 1 THEN 'Step0.5' END) AS 'Step0.5',
max(CASE WHEN [StepID] = 2 THEN 'StepI' END) AS 'StepI',
max(CASE WHEN [StepID] = 4 THEN 'StepI.D' END) AS 'StepI.D',
max(CASE WHEN [StepID] = 5 THEN 'StepII.1' END) AS 'StepII.1',
max(CASE WHEN [StepID] = 6 THEN 'StepII.5' END) AS 'StepII.5',
max(CASE WHEN [StepID] = 7 THEN 'StepII.D' END) AS 'StepII.D',
max(CASE WHEN [StepID] = 8 THEN 'StepIII.1' END) AS 'StepIII.1'
FROM RD.dbo.vwProvider as l INNER JOIN [RD].[dbo].[vwSteps] i ON l.ProviderID = i.ProviderID
Group by i.[ProviderID], l.FacilityName
ORDER BY FacilityName
Upvotes: 0
Reputation: 1269753
You need to remove StepId
from the GROUP BY
and introduce aggregation functions:
SELECT i.[ProviderID], l.FacilityName,
MAX(CASE WHEN [StepID] = 1 THEN 'Step0.5') END AS 'Step0.5',
MAX(CASE WHEN [StepID] = 2 THEN 'StepI' END) AS 'StepI',
MAX(CASE WHEN [StepID] = 4 THEN 'StepI.D' END) AS 'StepI.D',
MAX(CASE WHEN [StepID] = 5 THEN 'StepII.1' END) AS 'StepII.1',
MAX(CASE WHEN [StepID] = 6 THEN 'StepII.5' END) AS 'StepII.5',
MAX(CASE WHEN [StepID] = 7 THEN 'StepII.D' END) AS 'StepII.D',
MAX(CASE WHEN [StepID] = 8 THEN 'StepIII.1' END) AS 'StepIII.1'
FROM RD.dbo.vwProvider l INNER JOIN
[RD].[dbo].[vwSteps] i
ON l.ProviderID = i.ProviderID
Group by i.[ProviderID], l.FacilityName
ORDER BY FacilityName
Upvotes: 1