Obsah a struktura článku

Operátor UNION vám v SQL umožní propojit 2 výsledky dotazů a odstranit všechny duplicity, které v nich existují. Lze říci, že operátor ve výsledků provádí DISTINCT ve výsledném sjednocení záznamů. Tento operátor je podobný s UNION ALL – tady ale nedochází k odstranění duplicitních záznamů

Syntaxe

SELECT Sloupec
FROM dbo.Tabulka
WHERE Podmínka

     UNION

SELECT Sloupec
FROM dbo.Tabulka
WHERE Podmínka;

Syntaxe je stejně jako u všech Set operators stejná. Výsledkem sjednocení jsou všechny záznamy z obou tabulek s tím, že pokud dojde k tomu, že se v obou tabulkách nachází Sloupec se stejnou hodnotou, bude výsledkem bude pouze jedinečná hodnota.

(!!!) Operátor provede sjednocení a odstraní duplicity

Příklad UNION

Mějme tabulku se seznamem produktů.

SQL UNION

Pro ukázku 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

Evidentně se tak oba výběry překrývají, Product Keys <= 5 vybíráme dvakrát. Operátor by nám měl odstranit duplicity a vrátit pouze 10 záznamů

SELECT [ProductKey], [EnglishProductName]
FROM [AdventureWorksDW2014].[dbo].[DimProduct]
WHERE [ProductKey]<=10

      UNION

SELECT [ProductKey], [EnglishProductName]
FROM [AdventureWorksDW2014].[dbo].[DimProduct]
WHERE [ProductKey]<=5;

Výsledek

SQL UNION Výsledek

5/5 - (2 votes)

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, analytik a krátce jako finanční manažer. Vše pro společnosti z oblasti IT, bankovnictví a výroby. Po práci si rád zahraju tenis, volejbal, šachy, zajdu do posilovny a rád ochutnávám dobré rumy. 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í.

Leave a Reply

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