Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Leer UNION-Clausule | Geneste Subquery's
Intermediate SQL

bookUNION-Clausule

We hebben de aandacht getrokken van een klant die SQL-query's nodig heeft. Voordat we ingaan op JOINs, leren we eerst over de UNION-clausule, die essentieel is voor het combineren van meerdere tabellen.

Hier zijn enkele belangrijke zaken om te weten over het gebruik van UNION:

  1. Aantal kolommen en volgorde: Alle query's die met UNION worden gecombineerd, moeten hetzelfde aantal kolommen in dezelfde volgorde hebben;

  2. Gegevenstypen: De kolommen in elke query moeten compatibele gegevenstypen hebben;

  3. Unieke rijen: Standaard verwijdert UNION dubbele rijen. Gebruik UNION ALL als je duplicaten wilt behouden.

Voor een beter begrip van hoe je tabellen correct combineert 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 ziet dat deze tabel overeenkomsten vertoont met de employees-tabel. Met de UNION-clausule kunnen we deze twee tabellen combineren om bijvoorbeeld een lijst te zien van alle voor- en achternamen van werknemers en aannemers die bij het bedrijf betrokken zijn.

Hiervoor gebruiken we de UNION-clausule:

12345678
(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
copy

Laten we uitleggen wat er gebeurt:

We hebben twee queries die elk drie kolommen met dezelfde gegevenstypen retourneren. We willen de Id, first_name en last_name van iedereen in het bedrijf zien. We hebben de kolom Id ook hernoemd zodat beide queries dezelfde kolomnamen hebben.

Vervolgens gebruiken we UNION om de resultaten van deze queries te combineren, waarbij dubbele waarden worden verwijderd (hoewel die hier niet voorkomen).

Tot slot 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 één "grote samengestelde query" die we verder kunnen bewerken 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 het FROM-gedeelte. Hier is een voorbeeld van hoe dit te doen:

123456789
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'
copy

Het gebruik van een subquery in het FROM-gedeelte biedt meer flexibiliteit! Het kan in het begin lastig lijken, maar als je dit beheerst, wordt het schrijven van complexe queries veel eenvoudiger.

1. Welke kolommen zijn vereist bij het gebruik van de UNION-clausule in SQL?

2. Hoe behandelt de UNION-clausule standaard dubbele rijen?

question mark

Welke kolommen zijn vereist bij het gebruik van de UNION-clausule in SQL?

Select the correct answer

question mark

Hoe behandelt de UNION-clausule standaard dubbele rijen?

Select the correct answer

Was alles duidelijk?

Hoe kunnen we het verbeteren?

Bedankt voor je feedback!

Sectie 2. Hoofdstuk 5

Vraag AI

expand

Vraag AI

ChatGPT

Vraag wat u wilt of probeer een van de voorgestelde vragen om onze chat te starten.

Suggested prompts:

Can you explain the difference between UNION and UNION ALL?

How do I know when to use a subquery with UNION?

Can you show more examples of using UNION with different tables?

Awesome!

Completion rate improved to 4

bookUNION-Clausule

Veeg om het menu te tonen

We hebben de aandacht getrokken van een klant die SQL-query's nodig heeft. Voordat we ingaan op JOINs, leren we eerst over de UNION-clausule, die essentieel is voor het combineren van meerdere tabellen.

Hier zijn enkele belangrijke zaken om te weten over het gebruik van UNION:

  1. Aantal kolommen en volgorde: Alle query's die met UNION worden gecombineerd, moeten hetzelfde aantal kolommen in dezelfde volgorde hebben;

  2. Gegevenstypen: De kolommen in elke query moeten compatibele gegevenstypen hebben;

  3. Unieke rijen: Standaard verwijdert UNION dubbele rijen. Gebruik UNION ALL als je duplicaten wilt behouden.

Voor een beter begrip van hoe je tabellen correct combineert 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 ziet dat deze tabel overeenkomsten vertoont met de employees-tabel. Met de UNION-clausule kunnen we deze twee tabellen combineren om bijvoorbeeld een lijst te zien van alle voor- en achternamen van werknemers en aannemers die bij het bedrijf betrokken zijn.

Hiervoor gebruiken we de UNION-clausule:

12345678
(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
copy

Laten we uitleggen wat er gebeurt:

We hebben twee queries die elk drie kolommen met dezelfde gegevenstypen retourneren. We willen de Id, first_name en last_name van iedereen in het bedrijf zien. We hebben de kolom Id ook hernoemd zodat beide queries dezelfde kolomnamen hebben.

Vervolgens gebruiken we UNION om de resultaten van deze queries te combineren, waarbij dubbele waarden worden verwijderd (hoewel die hier niet voorkomen).

Tot slot 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 één "grote samengestelde query" die we verder kunnen bewerken 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 het FROM-gedeelte. Hier is een voorbeeld van hoe dit te doen:

123456789
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'
copy

Het gebruik van een subquery in het FROM-gedeelte biedt meer flexibiliteit! Het kan in het begin lastig lijken, maar als je dit beheerst, wordt het schrijven van complexe queries veel eenvoudiger.

1. Welke kolommen zijn vereist bij het gebruik van de UNION-clausule in SQL?

2. Hoe behandelt de UNION-clausule standaard dubbele rijen?

question mark

Welke kolommen zijn vereist bij het gebruik van de UNION-clausule in SQL?

Select the correct answer

question mark

Hoe behandelt de UNION-clausule standaard dubbele rijen?

Select the correct answer

Was alles duidelijk?

Hoe kunnen we het verbeteren?

Bedankt voor je feedback!

Sectie 2. Hoofdstuk 5
some-alt