Samouczek SQL

SQL HOME Wprowadzenie do SQL Składnia SQL Wybór SQL SQL Wybierz Wyraźne SQL Gdzie SQL i lub nie Kolejność SQL według SQL Wstaw do Puste wartości SQL Aktualizacja SQL Usuń SQL SQL Wybierz Góra Minimalna i maksymalna wartość SQL Liczba SQL, średnia, suma Polubienie SQL Symbole wieloznaczne SQL SQL In SQL między Aliasy SQL Połączenia SQL Wewnętrzne złącze SQL Połączenie lewe SQL Prawe połączenie SQL Pełne dołączenie do SQL Samoprzyłączanie SQL SQL Union Grupa SQL według Posiadanie SQL SQL istnieje SQL Dowolne, Wszystkie SQL Wybierz do Wstaw SQL do Wybierz Sprawa SQL Funkcje zerowe SQL Procedury składowane w SQL Komentarze SQL Operatory SQL

Baza danych SQL

Tworzenie bazy danych SQL Porzucona baza danych SQL Kopia zapasowa bazy danych SQL Utwórz tabelę SQL Tabela upuszczania SQL Zmień tabelę SQL Ograniczenia SQL SQL nie jest pusty Unikalny SQL Klucz podstawowy SQL Klucz obcy SQL Sprawdzanie SQL Domyślny SQL Indeks SQL Automatyczny przyrost SQL Daty SQL Widoki SQL Wstrzyknięcie SQL Hosting SQL Typy danych SQL

Referencje SQL

Słowa kluczowe SQL Funkcje MySQL Funkcje serwera SQL Funkcje dostępu MS Szybkie odwołanie do SQL

Przykłady SQL

Przykłady SQL Quiz SQL Ćwiczenia SQL Certyfikat SQL

Operator SQL UNII


Operator SQL UNII

Operator UNIONsłuży do łączenia zestawu wyników dwóch lub więcej SELECT instrukcji.

  • Każda SELECTinstrukcja w obrębie UNIONmusi mieć taką samą liczbę kolumn
  • Kolumny muszą mieć również podobne typy danych
  • Kolumny w każdym SELECTzestawieniu również muszą być w tej samej kolejności

Składnia UNION

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

UNION ALL Składnia

Operator UNIONdomyślnie wybiera tylko różne wartości. Aby zezwolić na zduplikowane wartości, użyj UNION ALL:

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

Uwaga: Nazwy kolumn w zestawie wyników są zwykle takie same jak nazwy kolumn w pierwszej SELECTinstrukcji.


Demo bazy danych

W tym samouczku użyjemy dobrze znanej przykładowej bazy danych Northwind.

Poniżej wybór z tabeli „Klienci”:

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

Oraz wybór z tabeli "Dostawcy":

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


Przykład SQL UNION

Poniższa instrukcja SQL zwraca miasta (tylko różne wartości) zarówno z tabeli „Klienci”, jak i „Dostawcy”:

Przykład

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

Uwaga: jeśli niektórzy klienci lub dostawcy mają to samo miasto, każde miasto zostanie wymienione tylko raz, ponieważ UNIONwybiera tylko różne wartości. Użyj UNION ALL, aby wybrać zduplikowane wartości!


Przykład SQL UNION ALL

Poniższa instrukcja SQL zwraca miasta (również zduplikowane wartości) z tabeli „Klienci” i „Dostawcy”:

Przykład

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

SQL UNION Z WHERE

Poniższa instrukcja SQL zwraca niemieckie miasta (tylko różne wartości) zarówno z tabeli „Klienci”, jak i „Dostawcy”:

Przykład

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

SQL UNION WSZYSTKO Z WHERE

Poniższa instrukcja SQL zwraca niemieckie miasta (również zduplikowane wartości) zarówno z tabeli „Klienci”, jak i „Dostawcy”:

Przykład

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

Kolejny przykład UNII

Poniższa instrukcja SQL zawiera listę wszystkich klientów i dostawców:

Przykład

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

Zwróć uwagę na powyższy „AS Type” — jest to alias. Aliasy SQL służą do nadawania tabeli lub kolumnie tymczasowej nazwy. Alias ​​istnieje tylko na czas trwania zapytania. Dlatego utworzyliśmy tutaj tymczasową kolumnę o nazwie „Typ”, która zawiera listę, czy osoba kontaktowa jest „Klientem” czy „Dostawcą”.