sql >> Database >  >> RDS >> Sqlserver

SQL Server 2012 PIVOT zonder aggregaat

Er zijn verschillende manieren waarop u de gegevens kunt transformeren. Sommige gebruiken een aggregatiefunctie en andere niet. Maar ook al draait u een string, u kunt nog steeds een aggregaat toepassen.

Samenvoegen met CASE:

select name,
  max(case when category = 'A' then 'X' else '' end) CategoryA,
  max(case when category = 'B' then 'X' else '' end) CategoryB,
  max(case when category = 'C' then 'X' else '' end) CategoryC,
  max(case when category = 'D' then 'X' else '' end) CategoryD
from yourtable 
group by name

Zie SQL Fiddle met demo

Statisch draaipunt:

U kunt nog steeds de PIVOT . gebruiken functie om de gegevens te transformeren, ook al zijn de waarden tekenreeksen. Als u een bekend aantal categorieën heeft, kunt u de zoekopdracht hardcoderen:

select name, 
  coalesce(A, '') CategoryA, 
  coalesce(B, '') CategoryB, 
  coalesce(C, '') CategoryC, 
  coalesce(C, '') CategoryD
from
(
  select name, category, 'X' flag
  from yourtable
) d
pivot
(
  max(flag)
  for category in (A, B, C, D)
) piv

Zie SQL Fiddle met demo .

Dynamisch draaipunt:

Als u een onbekend aantal categorieën heeft, kunt u dynamische SQL gebruiken:

DECLARE @cols AS NVARCHAR(MAX),
    @colsNull AS NVARCHAR(MAX),
    @query  AS NVARCHAR(MAX)

select @cols = STUFF((SELECT  ',' + QUOTENAME(category) 
                    from yourtable
                    group by category
                    order by category
            FOR XML PATH(''), TYPE
            ).value('.', 'NVARCHAR(MAX)') 
        ,1,1,'')

select @colsNull = STUFF((SELECT  ', coalesce(' + QUOTENAME(category)+', '''') as '+QUOTENAME('Category'+category)
                    from yourtable
                    group by category
                    order by category
            FOR XML PATH(''), TYPE
            ).value('.', 'NVARCHAR(MAX)') 
        ,1,1,'')


set @query = 'SELECT name, ' + @colsNull + ' 
              from 
             (
                select name, category, ''X'' flag
                from yourtable
            ) x
            pivot 
            (
                max(flag)
                for category in (' + @cols + ')
            ) p '

execute(@query)

Zie SQL Fiddle met demo .

Meerdere deelnames:

select c1.name,
  case when c1.category is not null then 'X' else '' end as CategoryA,
  case when c2.category is not null then 'X' else '' end as CategoryB,
  case when c3.category is not null then 'X' else '' end as CategoryC,
  case when c4.category is not null then 'X' else '' end as CategoryD
from yourtable c1
left join yourtable c2
  on c1.name = c2.name
  and c2.category = 'B'
left join yourtable c3
  on c1.name = c3.name
  and c3.category = 'C'
left join yourtable c4
  on c1.name = c4.name
  and c4.category = 'D'
where c1.category = 'A'

Zie SQL Fiddle met demo

Alle zoekopdrachten geven het resultaat:

| NAME | CATEGORYA | CATEGORYB | CATEGORYC | CATEGORYD |
--------------------------------------------------------
|  Joe |         X |         X |           |         X |
| Mary |         X |           |         X |         X |



  1. Selecteer en update rijen met datum 00/00/0000 00:00:00 00 in Oracle

  2. Een MySQL-datum opmaken in PHP

  3. Hoe de primaire sleutel voor een tabel in SQL Server bepalen?

  4. MySQL-prestaties:MySQL converteren naar MariaDB