Agregační funkce
Agregační funkce představují možnost sloučit záznamy či hodnoty do skupin a nad nimi provézt aritmetickou či statistickou operaci. Výsledkem jsou například počty záznamů (COUNT), součet hodnot (SUM), maximální hodnota (MAX) ze sady numerických hodnot apod. Seznam a význam agregačních funkcí:
COUNT(*) navrací počet počet řádků ve výsledku dotazu COUNT(DISTINCT) počet jedinečných výskytů hodnot SUM() součet numerických hodnot ze zadaného sloupce/pole hodnot AVG() aritmetický průměr z numerických platných hodnot MIN() minimální hodnotu z numerických platných hodnot MAX() maximální hodnota z numerických platných hodnot STD() směrodatnou odchylku GROUP BY sloučí záznamy se stejnými hodnotami určeného atributu a vytvoří souhrnnou hodnotu
Chceme-li zjistit počet všech zaměstnanců, použijeme operaci COUNT:
SELECT COUNT(*) FROM employees;
Chceme-li zjistit kolik zaměstnanců dostává provizi, použijeme operaci COUNT s názvem sloupce:
SELECT COUNT(commission_pct) FROM employees;
Počet je jiný, protože ve sloupci commission_pct jsou i hodnoty NULL, které funkce nezapočítává.
Jaký je nejvyšší plat v oddělení 80?
SELECT MAX(salary) FROM employees WHERE DEPARTMENT_ID=80;
Jaký je průměrný plat zaměstnanců v celé firmě?
SELECT AVG(salary) FROM employees;
Agregační funkce nelze použít v podmínce za WHERE, ale je možné je použít při seskupování za klauzulí GROUP BY. Chceme-li zjistit minimální platy v každém oddělení, seskupíme platy podle oddělení a v každé skupině je pak zjištěno minimum:
SELECT MIN(salary), department_id FROM employees GROUP BY department_id;
Jak by se dalo najít oddělení, na kterém je vyplácen minimální plat? Ověřte následující příkaz, případně jej upravte.
SELECT department_id FROM employees GROUP BY department_id HAVING MIN(salary);
Jak velké finance jsou vynaloženy každý rok na věškeré platy?
SELECT SUM(salary) FROM employees;
Kolik na platech čerpají jednotlivá oddělení za celý rok?
SELECT SUM(salary), department_id FROM employees GROUP BY department_id;
Kolik se vyplácí měsíčně? Sestavte dotaz sami.