sql >> Databáze >  >> RDS >> Sqlserver

Jak vytvořit kontingenční tabulku v Transact/SQL?

Musíte použít PIVOT . Můžete použít buď STATIC PIVOT, kde znáte hodnoty sloupců, které se mají transformovat, nebo DYNAMIC PIVOT, kde jsou sloupce neznámé až do doby provedení.

Statický pivot (Viz SQL Fiddle s ukázkou ):

select *
from 
(
    select memid, Condition_id, Condition_Result
    from t
) x
pivot
(
    sum(condition_result)
    for condition_id in ([C1], [C2], [C3], [C4])
) p

Dynamický pivot (Viz SQL Fiddle s ukázkou ):

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

SET @cols = STUFF((SELECT distinct ',' + QUOTENAME(c.condition_id) 
            FROM t c
            FOR XML PATH(''), TYPE
            ).value('.', 'NVARCHAR(MAX)') 
        ,1,1,'')


set @query = 'SELECT memid, ' + @cols + ' from 
            (
                select MemId, Condition_id, condition_result
                from t
           ) x
            pivot 
            (
                sum(condition_result)
                for condition_id in (' + @cols + ')
            ) p '


execute(@query)

Oba budou generovat stejné výsledky.




  1. Konfigurace MySQL pro Fluent NHibernate

  2. Simulace MySql OLD_PASSWORD v .NET nebo MS SQL?

  3. Funkce array_append nefunguje

  4. Počítání a seskupování stejného pojmenovaného sloupce v různých tabulkách (kde klauzule pouze z jedné tabulky)