Théorie des ensembles pour les jointures SQL

Jointure de données en SQL

Maham Faisal Khan

Senior Content Developer, DataCamp

Diagrammes de Venn et théorie des ensembles

Une figure montrant trois diagrammes de Venn : UNION, INTERSECT, et EXCEPT. Le diagramme UNION comporte deux cercles superposés, entièrement colorés en vert. Le diagramme INTERSECT comporte deux cercles qui se chevauchent, mais seule la partie qui se chevauche est colorée en vert. Le diagramme EXCEPT ne comporte que la partie du cercle de gauche qui n'a rien en commun avec le cercle de droite, colorée en vert

Jointure de données en SQL

Diagrammes de Venn et théorie des ensembles

Une image représentant trois diagrammes de Venn, dont deux sont ombrés. Seul le diagramme avec UNION est mis au point. Le diagramme UNION comporte deux cercles superposés, entièrement colorés en vert.

Jointure de données en SQL

UNION diagramme

  • UNION prend deux tableaux en entrée et renvoie tous les enregistrements des deux tableaux.

Un diagramme montrant deux tableaux, l'un à gauche et l'autre à droite. La partie droite du diagramme illustre ce qui se passe lorsqu'une opération UNION est effectuée sur les deux tableaux.

Jointure de données en SQL

UNION ALL diagramme

  • UNION ALL prend deux tableaux et renvoie tous les enregistrements des deux tableaux, y compris les doublons

Un diagramme montrant deux tableaux, l'un à gauche et l'autre à droite. La partie droite du diagramme illustre ce qui se passe lorsqu'une opération UNION ALL est effectuée sur les deux tableaux.

Jointure de données en SQL

UNION et UNION ALL syntaxe

Syntaxe

SELECT *
FROM left_table
UNION
SELECT *
FROM right_table;

Syntaxe

SELECT *
FROM left_table
UNION ALL
SELECT *
FROM right_table;
Jointure de données en SQL

UNION et UNION ALL syntaxe

Un diagramme montrant deux tableaux, l'un à gauche et l'autre à droite. La partie droite du diagramme illustre ce qui se passe lorsqu'une opération UNION est effectuée sur les deux tableaux. Les flèches indiquent que les tableaux de gauche et de droite nécessitent le même nombre de colonnes du même type de champ

Jointure de données en SQL

UNION et UNION ALL syntaxe

Un diagramme montrant deux tableaux, l'un à gauche et l'autre à droite. La partie droite du diagramme illustre ce qui se passe lorsqu'une opération UNION est effectuée sur les deux tableaux. Les flèches indiquent que le tableau de gauche et le tableau de droite nécessitent le même nombre de colonnes du même type de champ. Sur le côté droit, l'ensemble des résultats est affiché, en soulignant que le nom du champ est conservé à partir du tableau de droite, même en cas d'alias

Jointure de données en SQL

Au tableau des monarques

SELECT *
FROM monarchs;
| country        | continent   | monarch                 |
|----------------|-------------|-------------------------|
| Brunei         | Asia        | Hassanal Bolkiah        |
| Oman           | Asia        | Haitham bin Tarik       |
| Norway         | Europe      | Harald V                |
| United Kingdom | Europe      | Charles III             |
Jointure de données en SQL

Les premiers ministres rencontrent les monarques

SELECT monarch AS leader, country
FROM monarchs
UNION
SELECT prime_minister, country
FROM prime_ministers
ORDER BY country, leader
LIMIT 10;
Jointure de données en SQL

Après la UNION

|-------------------------|----------------|
| leader                  | country        |
|-------------------------|----------------|
| Anthony Albanese        | Australia      |
| Hassanal Bolkiah        | Brunei         |
| Mostafa Madbouly        | Egypt          |
| Narendra Modi           | India          |
| Christopher Luxon       | New Zealand    |
| Harald V                | Norway         |
| Jonas Gahr Støre        | Norway         |
| Haitham bin Tarik       | Oman           |
| Shehbaz Sharif          | Pakistan       |
| Luís Montenegro         | Portugal       |
|-------------------------|----------------|
Jointure de données en SQL

UNION ALL avec les dirigeants

SELECT monarch AS leader, country
FROM monarchs
UNION ALL
SELECT prime_minister, country
FROM prime_ministers
ORDER BY leader, country
LIMIT 10;
Jointure de données en SQL

Résultat

| leader                  | country        |
|-------------------------|----------------|
| Anthony Albanese        | Australia      |
| Hassanal Bolkiah        | Brunei         |
| Hassanal Bolkiah        | Brunei         |
| Mostafa Madbouly        | Egypt          |
| Narendra Modi           | India          |
| Christopher Luxon       | New Zealand    |
| Harald V                | Norway         |
| Jonas Gahr Støre        | Norway         |
| Haitham bin Tarik       | Oman           |
| Haitham bin Tarik       | Oman           |
Jointure de données en SQL

Passons à la pratique !

Jointure de données en SQL

Preparing Video For Download...