Maison >base de données >tutoriel mysql >Quelle est la principale différence entre Natural JOIN et Inner JOIN dans SQL ?

Quelle est la principale différence entre Natural JOIN et Inner JOIN dans SQL ?

Patricia Arquette
Patricia Arquetteoriginal
2025-01-06 01:12:42863parcourir

What's the Key Difference Between Natural JOIN and Inner JOIN in SQL?

Comprendre la distinction entre la jointure naturelle et la jointure interne

Dans le domaine du SQL (Structured Query Language), il est essentiel de comprendre le différences entre les jointures naturelles et internes. Ces types de jointure sont similaires mais distincts, ce qui a un impact sur la récupération des données résultante.

Une jointure interne, notée INNER JOIN ou USING, combine les lignes de deux tables en fonction de l'égalité dans une ou plusieurs colonnes spécifiées dans la clause ON. En revanche, une jointure naturelle, représentée par NATURAL JOIN, joint automatiquement les tables basées sur des colonnes qui partagent le même nom dans les deux tables.

Une distinction clé réside dans le nombre de colonnes renvoyées. Une jointure interne conserve toutes les colonnes des deux tables, tandis qu'une jointure naturelle exclut les colonnes en double portant le même nom. Cela se produit car la jointure naturelle suppose que les colonnes communes contiennent les mêmes données et sont redondantes.

Par exemple, considérons deux tables, TableA et TableB, avec Column1 comme colonne commune. Une jointure interne renverrait toutes les lignes des deux tables et inclurait les deux instances de Column1 :

SELECT * 
FROM TableA AS a 
INNER JOIN TableB AS b 
USING (Column1);

Sortie :

+------------+-----------+------------+-----------+
| a.Column1  | a.Column2 | b.Column1  | b.Column3 |
+------------+-----------+------------+-----------+
| 1          |  2        | 1          |   3       |
+------------+-----------+------------+-----------+

Cependant, une jointure naturelle entre TableA et TableB omettrait les redondants Colonne 1 :

SELECT * 
FROM TableA 
NATURAL JOIN TableB;

Sortie :

+------------+----------+----------+
| Column1    | Column2  | Column3  |
+------------+----------+----------+
| 1          |  2       |   3      |
+------------+----------+----------+

Il est crucial de noter que dans les jointures naturelles, les colonnes de jointure sont implicitement déterminées par leurs noms partagés, et vous ne pouvez pas les spécifier explicitement. De plus, les jointures naturelles ne peuvent être effectuées que sur des tables comportant une seule colonne commune.

Comprendre ces nuances entre les jointures internes et les jointures naturelles est essentiel pour une récupération efficace des données. En choisissant le type de jointure approprié, vous pouvez optimiser vos requêtes et obtenir les résultats souhaités.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn