Cursusinhoud
Intermediate SQL
Intermediate SQL
UNION-Clausule
We hebben de aandacht getrokken van een klant die SQL-query's nodig heeft. Voordat we ons verdiepen in JOINs
, laten we leren over de UNION
-clausule, die essentieel is voor het combineren van meerdere tabellen.
Hier zijn enkele belangrijke dingen om te weten over het gebruik van UNION
:
Kolommen Aantal en Volgorde: Alle query's gecombineerd met
UNION
moeten hetzelfde aantal kolommen in dezelfde volgorde hebben;Gegevenstypen: De kolommen in elke query moeten compatibele gegevenstypen hebben;
Unieke Rijen: Standaard verwijdert
UNION
dubbele rijen. GebruikUNION ALL
als je duplicaten wilt behouden.
Voor een beter begrip van hoe tabellen correct te combineren met behulp van de UNION
-clausule, heb ik een extra tabel geïntroduceerd die informatie bevat over contractors
.
Er is hier niet veel informatie, alleen de first_name
, last_name
en email
.
Je kunt zien dat deze tabel overeenkomsten vertoont met de employees
-tabel. Met behulp van de UNION
-clausule kunnen we deze twee tabellen combineren om bijvoorbeeld een lijst te zien van alle namen en achternamen van werknemers en aannemers die bij het bedrijf betrokken zijn.
Om dit te doen, zullen we de UNION
-clausule gebruiken:
(SELECT employee_id as id, first_name, last_name FROM employees) UNION (SELECT contractor_id as id, first_name, last_name FROM contractors) ORDER BY id
Laten we eens kijken wat er gebeurt:
We hebben twee queries die elk drie kolommen retourneren met dezelfde gegevenstypen. We willen de Id
, first_name
en last_name
van iedereen in het bedrijf zien. We hebben ook de Id
-kolom hernoemd zodat beide queries dezelfde kolomnamen hebben.
Vervolgens gebruiken we UNION
om de resultaten van deze queries te combineren, waarbij duplicaten worden verwijderd (hoewel er hier geen zijn).
Ten slotte sorteren we de resultaten op Id
met behulp van ORDER BY
.
Opmerking
We sorteren op
Id
, wat een gemeenschappelijke kolom is in beide tabellen.
Na het gebruik van UNION
krijgen we een "enkele grote query" die we verder kunnen manipuleren met clausules zoals ORDER BY
.
We kunnen WHERE
of GROUP BY
niet direct gebruiken met tabellen die zijn gecombineerd met UNION
. Om deze clausules toe te passen, moeten we een subquery gebruiken in de FROM
sectie. Hier is een voorbeeld van hoe je dat doet:
SELECT id, first_name, last_name FROM ( SELECT employee_id AS id, first_name, last_name FROM employees UNION SELECT contractor_id AS id, first_name, last_name FROM contractors ) AS combined WHERE first_name = 'Jane'
Een subquery gebruiken in de FROM
sectie geeft ons meer flexibiliteit! Het lijkt misschien in het begin lastig, maar het beheersen hiervan zal het schrijven van complexe queries veel gemakkelijker maken.
1. Welke kolommen zijn vereist bij het gebruik van de UNION
-clausule in SQL?
2. Hoe behandelt de UNION
-clausule standaard dubbele rijen?
Bedankt voor je feedback!