Výukový program MySQL

MySQL HOME Úvod do MySQL MySQL RDBMS

MySQL SQL

MySQL SQL MySQL SELECT MySQL KDE MySQL A NEBO NE MySQL OBJEDNAT PODLE MySQL INSERT INTO MySQL hodnoty NULL AKTUALIZACE MySQL MySQL DELETE LIMIT MySQL MySQL MIN a MAX MySQL COUNT, AVG, SUM MySQL LIKE Zástupné znaky MySQL MySQL IN MySQL MEZI Aliasy MySQL Připojení k MySQL VNITŘNÍ PŘIPOJENÍ k MySQL MySQL LEFT JOIN MySQL SPRÁVNÉ PŘIPOJENÍ SE MySQL CROSS JOIN Vlastní připojení k MySQL MySQL UNION MySQL GROUP BY MySQL MÁME MySQL EXISTUJE MySQL JAKÉKOLI, VŠECHNY MySQL INSERT SELECT CASE MySQL Funkce MySQL Null Komentáře k MySQL Operátoři MySQL

Databáze MySQL

MySQL Vytvořte DB MySQL Drop DB Vytvořit tabulku MySQL MySQL Drop Table MySQL Alter Table Omezení MySQL MySQL není Null Unikátní MySQL Primární klíč MySQL cizí klíč MySQL Kontrola MySQL Výchozí MySQL Vytvořit index MySQL Automatický přírůstek MySQL Data MySQL Zobrazení MySQL

Reference MySQL

MySQL datové typy Funkce MySQL

Příklady MySQL

Příklady MySQL MySQL kvíz Cvičení MySQL

Operátor MySQL UNION


Operátor MySQL UNION

Operátor UNIONse používá ke spojení výsledné sady dvou nebo více SELECT příkazů.

  • Každý SELECTpříkaz uvnitř UNIONmusí mít stejný počet sloupců
  • Sloupce musí mít také podobné datové typy
  • Sloupce v každém SELECTpříkazu musí být také ve stejném pořadí

Syntaxe UNION

SELECT column_name(s) FROM table1
UNION
SELECT column_name(s) FROM table2;

UNION ALL Syntaxe

Operátor UNIONve výchozím nastavení vybírá pouze odlišné hodnoty. Chcete-li povolit duplicitní hodnoty, použijte UNION ALL:

SELECT column_name(s) FROM table1
UNION ALL
SELECT column_name(s) FROM table2;

Poznámka: Názvy sloupců v sadě výsledků jsou obvykle stejné jako názvy sloupců v prvním SELECTpříkazu.


Demo databáze

V tomto tutoriálu použijeme známou ukázkovou databázi Northwind.

Níže je uveden výběr z tabulky „Zákazníci“:

CustomerID CustomerName ContactName Address City PostalCode Country
1

Alfreds Futterkiste Maria Anders Obere Str. 57 Berlin 12209 Germany
2 Ana Trujillo Emparedados y helados Ana Trujillo Avda. de la Constitución 2222 México D.F. 05021 Mexico
3 Antonio Moreno Taquería Antonio Moreno Mataderos 2312 México D.F. 05023 Mexico

A výběr z tabulky "Dodavatelé":

SupplierID SupplierName ContactName Address City PostalCode Country
1 Exotic Liquid Charlotte Cooper 49 Gilbert St. London EC1 4SD UK
2 New Orleans Cajun Delights Shelley Burke P.O. Box 78934 New Orleans 70117 USA
3 Grandma Kelly's Homestead Regina Murphy 707 Oxford Rd. Ann Arbor 48104 USA


Příklad SQL UNION

Následující příkaz SQL vrací města (pouze odlišné hodnoty) z tabulky "Zákazníci" i "Dodavatelé":

Příklad

SELECT City FROM Customers
UNION
SELECT City FROM Suppliers
ORDER BY City;

Poznámka: Pokud mají někteří zákazníci nebo dodavatelé stejné město, bude každé město uvedeno pouze jednou, protože UNIONvybírá pouze odlišné hodnoty. Použijte UNION ALLtaké k výběru duplicitních hodnot!


SQL UNION ALL Příklad

Následující příkaz SQL vrací města (také duplicitní hodnoty) z tabulky "Zákazníci" i "Dodavatelé":

Příklad

SELECT City FROM Customers
UNION ALL
SELECT City FROM Suppliers
ORDER BY City;

SQL UNION s WHERE

Následující příkaz SQL vrací německá města (pouze odlišné hodnoty) z tabulky "Zákazníci" i "Dodavatelé":

Příklad

SELECT City, Country FROM Customers
WHERE Country='Germany'
UNION
SELECT City, Country FROM Suppliers
WHERE Country='Germany'
ORDER BY City;

SQL UNION VŠE s WHERE

Následující příkaz SQL vrací německá města (také duplicitní hodnoty) z tabulky "Zákazníci" i "Dodavatelé":

Příklad

SELECT City, Country FROM Customers
WHERE Country='Germany'
UNION ALL
SELECT City, Country FROM Suppliers
WHERE Country='Germany'
ORDER BY City;

Další příklad UNION

Následující příkaz SQL uvádí všechny zákazníky a dodavatele:

Příklad

SELECT 'Customer' AS Type, ContactName, City, Country
FROM Customers
UNION
SELECT 'Supplier', ContactName, City, Country
FROM Suppliers;

Všimněte si výše uvedeného "AS Type" - je to alias. Aliasy SQL se používají k přidělení dočasného názvu tabulce nebo sloupci. Alias ​​existuje pouze po dobu trvání dotazu. Zde jsme tedy vytvořili dočasný sloupec s názvem "Typ", který uvádí, zda je kontaktní osoba "Zákazník" nebo "Dodavatel".