Table des matières
Connexion aux tables SQL
Maison base de données SQL Parlons des connexions aux tables SQL

Parlons des connexions aux tables SQL

Jun 15, 2022 am 11:55 AM
sql

Cet article vous apporte des connaissances pertinentes sur SQL, qui présente principalement le contenu pertinent sur les connexions de tables. SQL Server prend en charge une variété de connexions, notamment les jointures internes, les jointures gauches, les jointures droites, les jointures croisées et les jointures complètes. aux connexions extérieures. J'espère que cela sera utile à tout le monde.

Parlons des connexions aux tables SQL

Apprentissage recommandé : "Tutoriel SQL"

Connexion aux tables SQL

Dans une base de données relationnelle, les données sont réparties dans plusieurs tables logiques. Pour obtenir un ensemble de données complet et significatif, vous devez utiliser des jointures pour interroger les données de ces tables. SQL Server prend en charge diverses connexions, notamment les jointures internes, les jointures gauches, les jointures droites, les jointures croisées et les jointures externes complètes.

1. Jointure interne

La clause de jointure interne est utilisée pour interroger les données de deux ou plusieurs tables liées. La syntaxe de la clause INNER JOIN :

SELECT p.product_name, p.list_price ,c.category_nameFROM production.products p 
INNER JOIN production.categories c ON c.category_id = p.category_id
Copier après la connexion

Remarque : Le champ à interroger doit être précédé du nom de la table ou de l'alias de la table, tel que : p.product_name
Où le FROM suivant est la table principale, puis INNER JOIN est suivi. La table est la table à joindre. La table principale et la table de jointure sont comparées pour trouver toutes les lignes qui remplissent les conditions. Si le résultat du calcul du prédicat de connexion est vrai, la table principale et la table de connexion seront fusionnées dans un nouvel ensemble de résultats, comme le montre la figure suivante :

Parlons des connexions aux tables SQL

Connexions de tables multiples au sein de la connexion, comme indiqué ci-dessous :

SELECT p.product_name, p.list_price ,c.category_name, b.brand_nameFROM production.products p 
INNER JOIN production.categories c ON c.category_id = p.category_id 
INNER JOIN production.brands b ON b.brand_id = p.brand_id
Copier après la connexion

2. Jointure gauche

Utilisez la clause LEFT JOIN dans la jointure gauche pour interroger les données de plusieurs tables. Elle renvoie toutes les lignes de la table de gauche et les lignes correspondantes de la table de droite. Si aucune ligne correspondante n'est trouvée dans le tableau de droite, utilisez plutôt NULL pour l'affichage, comme indiqué dans la figure :

Parlons des connexions aux tables SQL

Utilisez l'instruction LEFT JOIN pour vous connecter : comme indiqué ci-dessous :

SELECT p.product_name, p.list_price ,c.category_nameFROM production.products p 
LEFT JOIN production.categories c ON c.category_id = p.category_id
Copier après la connexion

Dans la syntaxe ci-dessus, le tableau après FROM se trouve le tableau de gauche (production.products) et LEFT JOIN est suivi du tableau de droite (production.categories).

3. Jointure à droite

Utilisez la clause RIGHT JOIN dans la jointure à droite pour interroger deux tables ou plus. La requête de droite est juste l'opposé de la requête de gauche. Elle renvoie toutes les lignes de la table de droite et les lignes correspondantes de la table de gauche, si aucune ligne correspondante n'est trouvée dans la table de gauche, NULL est renvoyé au lieu d'être affiché, comme indiqué. dans la figure :

Parlons des connexions aux tables SQL

Utilisez l'instruction RIGHT JOIN pour vous connecter : comme suit :

SELECT p.product_name, p.list_price ,c.category_nameFROM production.products p 
RIGHT JOIN production.categories c ON c.category_id = p.category_id
Copier après la connexion

Dans la syntaxe ci-dessus, la table qui suit FROM est la table de gauche (production.products) et la table de droite (production.categories) immédiatement suivi de RIGHT JOIN.

4. Cross Join

CROSS JOIN rejoint deux ou plusieurs tables non liées. Voici la syntaxe de CROSS JOIN entre deux tables, deux façons d'écrire :

SELECT T1.select_list 
FROM T1 CROSS JOIN T2;
Copier après la connexion

ou

SELECT T1.select_list 
FROM T1, T2;
Copier après la connexion

CROSS JOIN connecte chaque ligne du premier tableau (T1) avec chaque ligne du deuxième tableau (T2). En d'autres termes, une jointure croisée renvoie le produit cartésien des lignes des deux tables. Contrairement à INNER JOIN ou LEFT JOIN, une jointure croisée n'établit pas de relation entre les tables jointes.
Supposons que le tableau T1 contienne trois lignes : 1 , 2 et 3 , et que le tableau T2 contienne trois lignes : A , B et C . CROSS JOIN prend une ligne de la première table (T1) et crée une nouvelle ligne pour chaque ligne de la deuxième table (T2). Ensuite, il fait de même pour la ligne suivante du premier tableau (T1), et ainsi de suite. Dans cette figure, le CROSS JOIN crée un total de 9 lignes.

5. Self-join

Self-join est utilisé pour connecter une table à elle-même (la même table). Il est utile pour interroger des données hiérarchiques ou comparer des lignes dans la même table.
L'auto-jointure utilise une clause de jointure interne ou de jointure gauche. Étant donné que les requêtes utilisant des jointures automatiques font référence à la même table, des alias de table sont utilisés pour attribuer des noms différents aux tables de la requête.
Remarque : Si vous référencez plusieurs fois la même table dans une requête sans utiliser d'alias de table, une erreur se produira.
Exemple :

SELECT t1.select_list 
FROM T1 t1INNER JOIN T1 t2 ON t1.category_id = t2.category_id
Copier après la connexion

Vous pouvez utiliser d'autres clauses ici dans INNER JOIN, telles que : LEFT JOIN, RIGHT JOIN

6. Jointure externe complète

FULL OUTER JOIN lorsqu'il y a un élément correspondant dans la gauche ou table de droite, la commande renverra toutes les lignes. Comme le montre la figure :

Parlons des connexions aux tables SQL

Utilisez FULL OUTER JOIN pour interroger les données de la table pm.projects et de la table pm.member :

SELECT m.name member, p.title project 
FROM pm.members m 
FULL OUTER JOIN pm.projects p ON p.id = m.project_id;
Copier après la connexion

données de la table pm.projects :
Parlons des connexions aux tables SQL

données de la table pm.member :

Parlons des connexions aux tables SQL

Résultats de la requête :
Parlons des connexions aux tables SQL

Apprentissage recommandé : "Tutoriel SQL"

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 de ce site Web
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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quelle est la différence entre HQL et SQL dans le framework Hibernate ? Quelle est la différence entre HQL et SQL dans le framework Hibernate ? Apr 17, 2024 pm 02:57 PM

HQL et SQL sont comparés dans le framework Hibernate : HQL (1. Syntaxe orientée objet, 2. Requêtes indépendantes de la base de données, 3. Sécurité des types), tandis que SQL exploite directement la base de données (1. Normes indépendantes de la base de données, 2. Exécutable complexe requêtes et manipulation de données).

Utilisation de l'opération de division dans Oracle SQL Utilisation de l'opération de division dans Oracle SQL Mar 10, 2024 pm 03:06 PM

"Utilisation de l'opération de division dans OracleSQL" Dans OracleSQL, l'opération de division est l'une des opérations mathématiques courantes. Lors de l'interrogation et du traitement des données, les opérations de division peuvent nous aider à calculer le rapport entre les champs ou à dériver la relation logique entre des valeurs spécifiques. Cet article présentera l'utilisation de l'opération de division dans OracleSQL et fournira des exemples de code spécifiques. 1. Deux méthodes d'opérations de division dans OracleSQL Dans OracleSQL, les opérations de division peuvent être effectuées de deux manières différentes.

Comparaison et différences de syntaxe SQL entre Oracle et DB2 Comparaison et différences de syntaxe SQL entre Oracle et DB2 Mar 11, 2024 pm 12:09 PM

Oracle et DB2 sont deux systèmes de gestion de bases de données relationnelles couramment utilisés, chacun possédant sa propre syntaxe et ses propres caractéristiques SQL. Cet article comparera et différera la syntaxe SQL d'Oracle et de DB2, et fournira des exemples de code spécifiques. Connexion à la base de données Dans Oracle, utilisez l'instruction suivante pour vous connecter à la base de données : CONNECTusername/password@database Dans DB2, l'instruction pour vous connecter à la base de données est la suivante : CONNECTTOdataba.

Explication détaillée de la fonction Définir la balise dans les balises SQL dynamiques MyBatis Explication détaillée de la fonction Définir la balise dans les balises SQL dynamiques MyBatis Feb 26, 2024 pm 07:48 PM

Interprétation des balises SQL dynamiques MyBatis : explication détaillée de l'utilisation des balises Set MyBatis est un excellent cadre de couche de persistance. Il fournit une multitude de balises SQL dynamiques et peut construire de manière flexible des instructions d'opération de base de données. Parmi elles, la balise Set est utilisée pour générer la clause SET dans l'instruction UPDATE, qui est très couramment utilisée dans les opérations de mise à jour. Cet article expliquera en détail l'utilisation de la balise Set dans MyBatis et démontrera ses fonctionnalités à travers des exemples de code spécifiques. Qu'est-ce que Set tag Set tag est utilisé dans MyBati

Que signifie l'attribut d'identité dans SQL ? Que signifie l'attribut d'identité dans SQL ? Feb 19, 2024 am 11:24 AM

Qu'est-ce que l'identité en SQL ? Des exemples de code spécifiques sont nécessaires. En SQL, l'identité est un type de données spécial utilisé pour générer des nombres à incrémentation automatique. Il est souvent utilisé pour identifier de manière unique chaque ligne de données dans une table. La colonne Identité est souvent utilisée conjointement avec la colonne clé primaire pour garantir que chaque enregistrement possède un identifiant unique. Cet article détaillera comment utiliser Identity et quelques exemples de code pratiques. La manière de base d'utiliser Identity consiste à utiliser Identit lors de la création d'une table.

Comment implémenter Springboot+Mybatis-plus sans utiliser d'instructions SQL pour ajouter plusieurs tables Comment implémenter Springboot+Mybatis-plus sans utiliser d'instructions SQL pour ajouter plusieurs tables Jun 02, 2023 am 11:07 AM

Lorsque Springboot+Mybatis-plus n'utilise pas d'instructions SQL pour effectuer des opérations d'ajout de plusieurs tables, les problèmes que j'ai rencontrés sont décomposés en simulant la réflexion dans l'environnement de test : Créez un objet BrandDTO avec des paramètres pour simuler le passage des paramètres en arrière-plan. qu'il est extrêmement difficile d'effectuer des opérations multi-tables dans Mybatis-plus. Si vous n'utilisez pas d'outils tels que Mybatis-plus-join, vous pouvez uniquement configurer le fichier Mapper.xml correspondant et configurer le ResultMap malodorant et long, puis. écrivez l'instruction SQL correspondante Bien que cette méthode semble lourde, elle est très flexible et nous permet de

Comment résoudre l'erreur 5120 dans SQL Comment résoudre l'erreur 5120 dans SQL Mar 06, 2024 pm 04:33 PM

Solution : 1. Vérifiez si l'utilisateur connecté dispose des autorisations suffisantes pour accéder ou utiliser la base de données, et assurez-vous que l'utilisateur dispose des autorisations appropriées ; 2. Vérifiez si le compte du service SQL Server est autorisé à accéder au fichier spécifié ou ; dossier et assurez-vous que le compte dispose des autorisations suffisantes pour lire et écrire le fichier ou le dossier ; 3. Vérifiez si le fichier de base de données spécifié a été ouvert ou verrouillé par d'autres processus, essayez de fermer ou de libérer le fichier et réexécutez la requête ; . Essayez en tant qu'administrateur, exécutez Management Studio en tant que etc.

Comment utiliser les instructions SQL pour l'agrégation de données et les statistiques dans MySQL ? Comment utiliser les instructions SQL pour l'agrégation de données et les statistiques dans MySQL ? Dec 17, 2023 am 08:41 AM

Comment utiliser les instructions SQL pour l'agrégation de données et les statistiques dans MySQL ? L'agrégation des données et les statistiques sont des étapes très importantes lors de l'analyse des données et des statistiques. En tant que puissant système de gestion de bases de données relationnelles, MySQL fournit une multitude de fonctions d'agrégation et de statistiques, qui peuvent facilement effectuer des opérations d'agrégation de données et de statistiques. Cet article présentera la méthode d'utilisation des instructions SQL pour effectuer l'agrégation de données et les statistiques dans MySQL, et fournira des exemples de code spécifiques. 1. Utilisez la fonction COUNT pour compter. La fonction COUNT est la plus couramment utilisée.

See all articles