Operátor UNION ALL v SQL umožnujě provést sjednocení 2 výsledky dotazů s tím, že neodstraní duplicity v dotazech. Operátor vrátí všechny záznamy z obou dotazů bez ohledu na duplicity, které v nich existují.
UNION ALL patří do skupiny tzv. SET operators spolu s UNION, EXCEPT, INTERSECT
Syntaxe:
SELECT Sloupec
FROM dbo.Tabulka
WHERE Podmínka
UNION ALL
SELECT Sloupec
FROM dbo.Tabulka
WHERE Podmínka
Syntaxe je opět podobná jako u všech Set operators. Tento dotaz vrátí všechny záznamy z obou dotazů bez ohledy na duplicity ve sloupci [Sloupec]
Příklad SQL UNION ALL
Zadání úkolu bude stejné jako u Příkladu s operátorem UNION. Mějme tabulku se seznamem produktů:
Znovu uděláme sjednocení 2 dotazů:
- První dotaz – budou záznamy kde Product Key (Primární klíč) je měnší než 10
- Druhý dotaz – budou záznamy kde Product Key (Primární klíč) je měnší než 5
Oba výběry se překrývají, Product Keys <= 5 vybíráme dvakrát. Operátor by nám měl vrátit všech 15 záznamů (10 z Prvního dotazu; 5 z druhého). UNION nám vrátil 10 záznamů
SELECT [ProductKey], [EnglishProductName]
FROM [AdventureWorksDW2014].[dbo].[DimProduct]
WHERE [ProductKey]<=10
UNION ALL
SELECT [ProductKey], [EnglishProductName]
FROM [AdventureWorksDW2014].[dbo].[DimProduct]
WHERE [ProductKey]<=5
Výsledkem je všech 15 záznamů
Posledních 5 záznamů z tabulky jsou duplicity