Table des matières
Requête de connexion
Classification de requêtes de jointure
Phénomène de produit cartésien
Equi-jointures de. jointures internes
Inner join self-join
Jointure non équivalente de la jointure interne
Jointure externe
内连接和外连接的特点
多表连接
Maison base de données tutoriel mysql Comment résoudre le problème de requête de connexion dans MySql

Comment résoudre le problème de requête de connexion dans MySql

May 26, 2023 pm 08:48 PM
mysql

    Requête de connexion

    Lors de l'exécution d'une requête de connexion multi-tables, vous devez spécifier la table à laquelle appartient le champ, ce qui peut améliorer l'efficacité de la requête si vous ne spécifiez pas la table à laquelle appartient le champ, la base de données. recherchera le champ de chaque table

    • e . Nom du champ : Représente la prise d'un certain champ de la table emp

    • emp comme e : Le mécanisme d'alias de la table, vous pouvez omettre as et l'écrire directement comme. emp e

    • Requête de connexion : elle peut également être appelée requête croisée, ce qui est nécessaire. Associez plusieurs tables pour interroger les données ensemble

    • Rejoignez la table emp et la table dept pour interroger les données, prenez le nom de l'employé de la table emp et prenez le nom du département de la table dept

    Remarque : assurez-vous de faire la requête de connexion lorsque vous faites Il est nécessaire d'écrire les conditions associées pour éviter le phénomène de produit cartésien

    Classification de requêtes de jointure

    Classification basée sur l'âge de la grammaire

    SQL92 :La grammaire apparue en 1992

    • Inconvénients de sql92 : La structure n'est pas claire, les conditions de connexion de la table, et les conditions pour un filtrage ultérieur dans une étape ultérieure, tous sont placés après où

    SQL99 : La syntaxe apparue en 1999 (apprentissage des clés)

    • sql99 avantages : conditions de connexion aux tables et requêtes Séparation conditionnelle, si un filtrage supplémentaire est nécessaire après la connexion, continuez à ajouter où plus tard, ce sera plus clair lors de la connexion de plusieurs tables

    Classification selon le mode de connexion de la table

    Jointure interne : jointure égale, jointure non égale Jointure de valeur, auto-jointure , l'intérieur peut être omis et généralement non ajouté

    • Table A jointure interne Tableau B sur les conditions d'association

    Jointure externe : jointure externe gauche (jointure gauche), jointure externe droite (jointure droite), boîte externe Généralement pas ajoutez

    • table A jointure externe gauche table B sur condition d'association

    • table B jointure externe droite table A sur condition d'association

    • La jointure gauche doit être basée sur la table de gauche et comparée à la table à droite. Toutes les inégalités égales au tableau de gauche seront affichées, tandis que celles du tableau de droite qui remplissent les conditions seront affichées, et celles qui ne remplissent pas les conditions ne seront pas affichées (la jointure de droite est juste le contraire). )

    • La fonction que la jointure gauche peut remplir peut certainement être complétée par la jointure droite

    Jointure complète, les deux tables connectées sont toutes deux des tables principales et peuvent être interrogées

    Phénomène de produit cartésien

    Quand deux les tables sont connectées pour la requête et aucune condition de connexion n'est spécifiée, le nombre final de résultats de requête est de deux entrées de table Le produit des nombres, ce phénomène est appelé : Phénomène de produit cartésien (découvert par Descartes, c'est un phénomène mathématique)

    Évitez le Phénomène de produit cartésien : ajoutez des conditions de connexion lors de la connexion de plusieurs tables, et les enregistrements qui remplissent cette condition ont été filtrés

    • Le nombre de correspondances n'a pas diminué pendant le processus de correspondance, mais le nombre de résultats finaux de la requête est devenu inférieur car il était filtré en fonction des conditions de connexion

    • On peut conclure grâce au phénomène de produit cartésien que la table Plus le nombre de connexions est élevé, plus l'efficacité est faible. Essayez d'éviter le nombre de connexions de table

    Equi-jointures de. jointures internes

    Parce que les conditions sont égales, elles sont appelées équi-jointures (données qui joignent des conditions égales)

    Recherchez le nom du service où se trouve chaque employé, affichez le nom de l'employé et le service

    emp e et Les tables du département d sont connectées, la condition de connexion est : e.deptno = d.deptno

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    --sql92的缺点:结构不清晰,表的连接条件,和后期进一步筛选的条件,都放到了where后面

     

    select

        e.ename,d.dname

    from

        emp e, dept d

    where

        e.deptno = d.deptno;

         

    --sql99优点:表连接的条件是独立的,连接之后,如果还需要进一步筛选,再往后继续添加where      

    select

        e.ename,d.dname

    from

        emp e

    --inner可以省略(带着inner可读性更好)

    (inner) join

        dept d

    on

        e.deptno = d.deptno;

    Copier après la connexion

    Inner join self-join

    Parce qu'il n'y a qu'une seule table de connexion, la méthode de requête spécifique consiste à traiter une table comme deux tables et à se connecter eux-mêmes, cela devient donc une auto-adhésion

    Pour interroger le leader supérieur de l'employé, il est nécessaire d'afficher le nom de l'employé et le nom du leader correspondant

    Une table est traitée comme deux tables Zhang, emp e représente la table des employés , et emp m représente également la table des leaders

    Conditions de connexion : e.mgr = m.empno numéro d'employé du leader = numéro d'employé du leader

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    --SQL92

    select e.ename, m.ename from emp e, emp m where e.mgr=m.empno;

     

    --SQL99

    select

        a.ename as '员工名', b.ename as '领导名'

    from

        emp e

    join

        emp m

    on

        e.mgr = m.empno;

    Copier après la connexion

    Jointure non équivalente de la jointure interne

    Parce que la condition de connexion n'est pas une relation d'équivalence, cela s'appelle une connexion non équivalente

    Afficher les informations sur les employés dont le salaire est supérieur à 2000, et afficher le nom du service auquel il appartient

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    --采用 SQL92 语法

    select

        e.ename, e.sal, d.dname

    from

        emp e, dept d

    where

        e.deptno=d.deptno and e.sal > 2000;

         

    --采用 SQL99 语法

    select

        e.ename, e.sal, d.dname

    from

        emp e

    (inner) join

        dept d

    on

        e.deptno=d.deptno

    where

        e.sal>2000;

    Copier après la connexion

    Connaître l'échelon salarial de chaque employé et exiger l'affichage de employés Nom, salaire, grade de salaire

    1

    2

    3

    4

    5

    6

    7

    8

    select

        e.ename, e.sal, s.grade

    from

        emp e

    (inner) join

        salgrade s

    on

        e.sal between s.losal and s.hisal;

    Copier après la connexion

    Jointure externe

    Jointure externe : dans la jointure externe, la connexion de deux tables crée une relation primaire et secondaire. La requête principale concerne les données de la table principale et de la table secondaire. est interrogé avec l'association, c'est-à-dire si l'autre partie S'il n'y a aucun enregistrement correspondant à ma table principale, alors la contrepartie par défaut est nulle et le mot-clé externe peut être omis

    • Jointure externe droite : celle avec le droit est une jointure externe droite, ce qui signifie que la table à droite du mot clé join est considérée comme la table principale, principalement pour interroger toutes les données de cette table, et interroger la table de gauche avec l'association

    • Left external join : avec left t est une jointure externe gauche, ce qui signifie regarder la table à gauche du mot-clé join. La table principale consiste à interroger toutes les données de cette table et à interroger la table de droite avec l'association

    **Remarque : toute jointure à droite a une jointure à gauche, et toute jointure à gauche a une droite. Comment écrire une connexion**

    查询每个员工的上级领导,要求显示所有员工的名字和领导名 , 如果某个员工没有领导 , 那么该员工也必须显示出来

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    --左连接

    select

        a.ename as '员工名', b.ename as '领导名'

    from

        emp a

    left (outer) join

        emp b

    on

        a.mgr = b.empno;

     

    --右连接

    select

        a.ename as '员工名', b.ename as '领导名'

    from

        emp b

    right (outer) join

        emp a

    on

        a.mgr = b.empno;

    Copier après la connexion

    内连接和外连接的特点

    内连接:A表和B表连接,A和B两张表没有主次关系是平等的 , 查询时只是将能够匹配上连接条件的数据查询出来 , 即如果没有匹配的就查询不出来 , inner关键字可以省略

    外连接: 在外连接当中,两张表连接产生了主次关系 , 主要查询的是主表的数据 , 捎带着关联查询次表 , 即如果对方没有记录和我主表匹配 , 那么默认对方是null , outer关键字可以省略

    注意: 区分内外连接的办法是通过 right 和 left 关键字 , 不是通过 inner 和 outer 因为它们都可以省略 , 并且外连接的查询结果条数一定是大于等于内连接的查询结果条数

    显示员工信息,并显示所属的部门名称

    1

    2

    3

    4

    5

    6

    7

    8

    select

        e.ename,d.dname

    from

        emp e

    join

        dept d

    on

        e.deptno = d.deptno;

    Copier après la connexion

    Comment résoudre le problème de requête de connexion dans MySql

    显示员工信息,并显示所属的部门名称,如果某一个部门没有员工,那么该部门也必须显示出来

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    20

    21

    22

    23

    --外连接(右外连接)

    select

        e.ename,d.dname

    from

        emp e

    --outer是可以省略的,带着可读性强

    --right代表什么:表示将join关键字右边的这张表看成主表,主要是为了将这张表的数据全部查询出来,捎带着关联查询左边的表

    right (outer) join

        dept d

    on

        e.deptno = d.deptno;

     

     

    --外连接(左外连接)

    select

        e.ename,d.dname

    from

        dept d

    --outer是可以省略的,带着可读性强

    left (outer) join

        emp e

    on

        e.deptno = d.deptno;

    Copier après la connexion

    Comment résoudre le problème de requête de connexion dans MySql

    多表连接

    一条SQL中内连接和外连接可以混合 , 都可以出现

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    --表示一: a 和 b 进行内连接 , a 和 c 进行内连接 , a 和 d 进行右外连接(推荐)

     

    --表示二: a 和 b 的内连接结果去内连接 c 的结果再去右外连接 d

    select

        ...

    from

        a

    join

        b

    on

        a和b的连接条件

    join

        c

    on

        a和c的连接条件

    right join

        d

    on

        a和d的连接条件

    Copier après la connexion

    找出每个员工的部门名称以及工资等级,要求显示员工名、部门名、薪资、薪资等级

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    select

        e.ename,e.sal,d.dname,s.grade

    from

        emp e

    join

        dept d

    on

        e.deptno = d.deptno

    join

        salgrade s

    on

        e.sal between s.losal and s.hisal;

    Copier après la connexion

    查询结果

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    +--------+---------+------------+-------+

    | ename  | sal     | dname      | grade |

    +--------+---------+------------+-------+

    | SMITH  |  800.00 | RESEARCH   |     1 |

    | ALLEN  | 1600.00 | SALES      |     3 |

    | WARD   | 1250.00 | SALES      |     2 |

    | JONES  | 2975.00 | RESEARCH   |     4 |

    | MARTIN | 1250.00 | SALES      |     2 |

    | BLAKE  | 2850.00 | SALES      |     4 |

    | CLARK  | 2450.00 | ACCOUNTING |     4 |

    | SCOTT  | 3000.00 | RESEARCH   |     4 |

    | KING   | 5000.00 | ACCOUNTING |     5 |

    | TURNER | 1500.00 | SALES      |     3 |

    | ADAMS  | 1100.00 | RESEARCH   |     1 |

    | JAMES  |  950.00 | SALES      |     1 |

    | FORD   | 3000.00 | RESEARCH   |     4 |

    | MILLER | 1300.00 | ACCOUNTING |     2 |

    +--------+---------+------------+-------+

    Copier après la connexion

    找出每个员工的部门名称以及工资等级,还有上级领导,要求显示员工名、领导名、部门名、薪资、薪资等级

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    select

        e.ename,e.sal,d.dname,s.grade,l.ename

    from

        emp e

    join

        dept d

    on

        e.deptno = d.deptno

    join

        salgrade s

    on

        e.sal between s.losal and s.hisal

    left join

        emp l

    on

        e.mgr = l.empno;

    Copier après la connexion

    查询结果

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    +--------+---------+------------+-------+-------+

    | ename  | sal     | dname      | grade | ename |

    +--------+---------+------------+-------+-------+

    | SMITH  |  800.00 | RESEARCH   |     1 | FORD  |

    | ALLEN  | 1600.00 | SALES      |     3 | BLAKE |

    | WARD   | 1250.00 | SALES      |     2 | BLAKE |

    | JONES  | 2975.00 | RESEARCH   |     4 | KING  |

    | MARTIN | 1250.00 | SALES      |     2 | BLAKE |

    | BLAKE  | 2850.00 | SALES      |     4 | KING  |

    | CLARK  | 2450.00 | ACCOUNTING |     4 | KING  |

    | SCOTT  | 3000.00 | RESEARCH   |     4 | JONES |

    | KING   | 5000.00 | ACCOUNTING |     5 | NULL  |

    | TURNER | 1500.00 | SALES      |     3 | BLAKE |

    | ADAMS  | 1100.00 | RESEARCH   |     1 | SCOTT |

    | JAMES  |  950.00 | SALES      |     1 | BLAKE |

    | FORD   | 3000.00 | RESEARCH   |     4 | JONES |

    | MILLER | 1300.00 | ACCOUNTING |     2 | CLARK |

    +--------+---------+------------+-------+-------+

    Copier après la connexion

    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 !

    Article chaud

    <🎜>: Grow A Garden - Guide de mutation complet
    3 Il y a quelques semaines By DDD
    <🎜>: Bubble Gum Simulator Infinity - Comment obtenir et utiliser les clés royales
    3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
    Nordhold: Système de fusion, expliqué
    3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
    Blue Prince: Comment se rendre au sous-sol
    1 Il y a quelques mois By DDD

    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)

    Sujets chauds

    Tutoriel Java
    1664
    14
    Tutoriel PHP
    1269
    29
    Tutoriel C#
    1248
    24
    Rôle de MySQL: Bases de données dans les applications Web Rôle de MySQL: Bases de données dans les applications Web Apr 17, 2025 am 12:23 AM

    Le rôle principal de MySQL dans les applications Web est de stocker et de gérer les données. 1.MySQL traite efficacement les informations utilisateur, les catalogues de produits, les enregistrements de transaction et autres données. 2. Grâce à SQL Query, les développeurs peuvent extraire des informations de la base de données pour générer du contenu dynamique. 3.MySQL fonctionne basé sur le modèle client-serveur pour assurer une vitesse de requête acceptable.

    Exemple d'introduction de Laravel Exemple d'introduction de Laravel Apr 18, 2025 pm 12:45 PM

    Laravel est un cadre PHP pour la création facile des applications Web. Il fournit une gamme de fonctionnalités puissantes, notamment: Installation: Installez le Laravel CLI globalement avec Composer et créez des applications dans le répertoire du projet. Routage: définissez la relation entre l'URL et le gestionnaire dans Routes / web.php. Voir: Créez une vue dans les ressources / vues pour rendre l'interface de l'application. Intégration de la base de données: fournit une intégration prête à l'emploi avec des bases de données telles que MySQL et utilise la migration pour créer et modifier des tables. Modèle et contrôleur: le modèle représente l'entité de la base de données et le contrôleur traite les demandes HTTP.

    Mysql et phpmyadmin: fonctionnalités et fonctions de base Mysql et phpmyadmin: fonctionnalités et fonctions de base Apr 22, 2025 am 12:12 AM

    MySQL et PHPMyAdmin sont de puissants outils de gestion de la base de données. 1) MySQL est utilisé pour créer des bases de données et des tables et pour exécuter des requêtes DML et SQL. 2) PHPMYADMIN fournit une interface intuitive pour la gestion des bases de données, la gestion de la structure de la table, les opérations de données et la gestion de l'autorisation des utilisateurs.

    MySQL vs d'autres langages de programmation: une comparaison MySQL vs d'autres langages de programmation: une comparaison Apr 19, 2025 am 12:22 AM

    Par rapport à d'autres langages de programmation, MySQL est principalement utilisé pour stocker et gérer les données, tandis que d'autres langages tels que Python, Java et C sont utilisés pour le traitement logique et le développement d'applications. MySQL est connu pour ses performances élevées, son évolutivité et son support multiplateforme, adapté aux besoins de gestion des données, tandis que d'autres langues présentent des avantages dans leurs domaines respectifs tels que l'analyse des données, les applications d'entreprise et la programmation système.

    Résolvez le problème de la connexion de la base de données: un cas pratique d'utilisation de la bibliothèque Minii / DB Résolvez le problème de la connexion de la base de données: un cas pratique d'utilisation de la bibliothèque Minii / DB Apr 18, 2025 am 07:09 AM

    J'ai rencontré un problème délicat lors du développement d'une petite application: la nécessité d'intégrer rapidement une bibliothèque d'opération de base de données légère. Après avoir essayé plusieurs bibliothèques, j'ai constaté qu'ils avaient trop de fonctionnalités ou ne sont pas très compatibles. Finalement, j'ai trouvé Minii / DB, une version simplifiée basée sur YII2 qui a parfaitement résolu mon problème.

    Méthode d'installation de Laravel Framework Méthode d'installation de Laravel Framework Apr 18, 2025 pm 12:54 PM

    Résumé de l'article: Cet article fournit des instructions détaillées étape par étape pour guider les lecteurs sur la façon d'installer facilement le cadre Laravel. Laravel est un puissant cadre PHP qui accélère le processus de développement des applications Web. Ce didacticiel couvre le processus d'installation des exigences du système à la configuration des bases de données et à la configuration du routage. En suivant ces étapes, les lecteurs peuvent jeter rapidement et efficacement une base solide pour leur projet Laravel.

    MySQL pour les débutants: commencer la gestion de la base de données MySQL pour les débutants: commencer la gestion de la base de données Apr 18, 2025 am 12:10 AM

    Les opérations de base de MySQL incluent la création de bases de données, les tables et l'utilisation de SQL pour effectuer des opérations CRUD sur les données. 1. Créez une base de données: CreatedAtAbaseMy_First_DB; 2. Créez un tableau: CreateTableBooks (idIntauto_inCmentPrimaryKey, TitleVarchar (100) notnull, AuthorVarchar (100) notnull, publied_yearint); 3. Données d'insertion: INSERTINTOBOOKS (titre, auteur, publié_year) VA

    Résoudre MySQL Mode Problem: L'expérience de l'utilisation du module TheliamysQlModeschecker Résoudre MySQL Mode Problem: L'expérience de l'utilisation du module TheliamysQlModeschecker Apr 18, 2025 am 08:42 AM

    Lors du développement d'un site Web de commerce électronique à l'aide de Thelia, j'ai rencontré un problème délicat: le mode MySQL n'est pas réglé correctement, ce qui fait que certaines fonctionnalités ne fonctionnent pas correctement. Après une certaine exploration, j'ai trouvé un module appelé TheliamysqlModeschecker, qui est capable de réparer automatiquement le motif MySQL requis par Thelia, résolvant complètement mes problèmes.

    See all articles