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

Jak vytvořit pivotní dotaz na serveru SQL bez agregační funkce

SELECT *
FROM
(
SELECT [Period], [Account], [Value]
FROM TableName
) AS source
PIVOT
(
    MAX([Value])
    FOR [Period] IN ([2000], [2001], [2002])
) as pvt

Jiný způsob,

SELECT ACCOUNT,
      MAX(CASE WHEN Period = '2000' THEN Value ELSE NULL END) [2000],
      MAX(CASE WHEN Period = '2001' THEN Value ELSE NULL END) [2001],
      MAX(CASE WHEN Period = '2002' THEN Value ELSE NULL END) [2002]
FROM tableName
GROUP BY Account
  • Ukázka SQLFiddle (oba dotazy )


  1. Existuje možnost/funkce MySQL pro sledování historie změn záznamů?

  2. Načítání kompletních chybových zpráv v isql

  3. Jak zabránit poškození databáze v aplikaci Microsoft Access

  4. EF 6 - Jak správně provádět paralelní dotazy