• 20.8.2016
  • Ing. Jan Zedníček - Data & Finance
  • 1

GROUP BY klauzuli používáme v SQL k seskupování záznamů. Ve většině případů jde o situaci, kdy potřebujeme udělat nějakou agregační operaci v tabulce (součet tržeb, počet záznamů, průměr, apod).

Pořadí klauzule v SQL skriptu

  1. SELECT
  2. FROM
  3. WHERE
  4. GROUP BY
  5. HAVING
  6. ORDER BY

Syntaxe GROUP BY:

SELECT [Sloupec1], [Sloupec2], AgregacniFunkce([Sloupec3]) AS Alias
FROM Tabulka
WHERE Podminka
GROUP BY Sloupec1, Sloupec2

Pokud použijeme agragační funkci, tak většinou tuto klauzuli použijeme. Výjimkou jsou situace, kdy do agregační funkce ještě zahrneme operátor OVER( PARTITION BY| ORDER BY|ROW|RANGE), ten řadíme mezi pokročilejší znalosti a proto s ním zatím nemusíme ztrácet čas. Pro začátečníky budiž pravidlem, že je klauzule je povinná, pokud v SELECT existuje nějaká agregační funkce.

Příklad použití

Tabulka [FactInternetSales] má spoustu polí jak je vidět z obrázku, ale my budeme pracovat pouze se 2-ma poli:

  • Datum [OrderDate]
  • Částka [SalesAmount]
SQL Server GROUP BY příklad
Příklad

Budeme chtít agregovat částku podle datumů a výsledek poté seřadit sestupně. Použijeme k tomu:

  • agregační funkci SUM() v klauzuli SELECT
  • GROUP BY
  • ORDER BY

SELECT [OrderDate] AS Datum
,SUM([SalesAmount]) AS Soucet
FROM [AdventureWorksDW2012].[dbo].[FactInternetSales]
GROUP BY [OrderDate]
ORDER BY [OrderDate] DESC

a výsledek:

SQL GROUP BY
Výsledek

Kdybychom klauzuli vynechali, tak by výsledkem byla chyba

“Column ‘AdventureWorksDW2012.dbo.FactInternetSales.OrderDate’ is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause.”

Chybová hláška nás upozorňuje, že není sloupec OrderDate obsažen v klauzuli

GROUP BY chybový stav
Chybová hláška
5/5 - (4 votes)

Ing. Jan Zedníček - Data & Finance

Jmenuji se Honza Zedníček a působím jako freelancer. Tuto práci dělám pro různé firmy již přes 10 let. Před tím jsem dlouhou dobu pracoval také jako BI developer, finanční controller a analytik. Vše pro společnosti z oblasti IT, bankovnictví a výroby. Po práci si rád zahraju tenis, volejbal, šachy a zajdu do posilovny. Svoje znalosti a názory se snažím už několik let zapisovat na tento web, aby sloužily i někomu dalšímu - zejména studentům a zájemcům o informace z oblastí Business intelligence, korporátních financí a reportingu.

=> Přihlašte se do naší Excel facebook skupiny (1.4k+ členů), kde si pomáháme Excel CZ/SK diskuse »
=> Pokud vám článek pomohl, sdílejte ho nebo mě uveďte na vašich webových stránkách jako užitečný zdroj informací.

1 comment on “SQL GROUP BY – Agregujte záznamy

  1. Děkuji za to, že někdo si dal tu práci a sepsal to a já to tím pádem mohl pochopit.

Leave a Reply

Your email address will not be published. Required fields are marked *