Maison > base de données > tutoriel mysql > le corps du texte

Comment utiliser JOIN dans MySQL

WBOY
Libérer: 2023-06-03 09:30:35
avant
1519 Les gens l'ont consulté

Introduction

Comment utiliser JOIN dans MySQL

  • Exclusivité A + public AB

  • Exclusivité B + public AB

  • Public AB

  • Exclusivité A

  • B's Unique

  • A's unique+B's unique +AB's public

  • A's unique+B's unique

Exercice

Construire une table

Table de département

DROP TABLE IF EXISTS `dept`;
CREATE TABLE `dept` (
	`dept_id` int(11) NOT NULL AUTO_INCREMENT,
    `dept_name` varchar(30) DEFAULT NULL,
    `dept_number` int(11) DEFAULT NULL,
    PRIMARY KEY (`dept_id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

INSERT INTO `dept` VALUES ('1', 'AA', '100');
INSERT INTO `dept` VALUES ('2', 'BB', '200');
INSERT INTO `dept` VALUES ('3', 'CC', '300');
INSERT INTO `dept` VALUES ('4', 'DD', '400');
INSERT INTO `dept` VALUES ('5', 'HH', '500');
Copier après la connexion

Table des employés

DROP TABLE IF EXISTS `emp`;
CREATE TABLE `emp` (
    `emp_id` int(11) NOT NULL AUTO_INCREMENT,
    `emp_name` varchar(30) DEFAULT NULL,
    `emp_age` int(11) DEFAULT NULL,
    `dept_id` int(11) NOT NULL,
    PRIMARY KEY (`emp_id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

INSERT INTO `emp` VALUES('1', 'zhangsan', '20', '1');
INSERT INTO `emp` VALUES('2', 'lisi', '25', '6');
INSERT INTO `emp` VALUES('3', 'wangwu', '19', '4');
INSERT INTO `emp` VALUES('4', 'zhaoliu', '29', '5');
INSERT INTO `emp` VALUES('5', 'xiaohong', '30', '2');
INSERT INTO `emp` VALUES('6', 'xiaohu', '26', '3');
INSERT INTO `emp` VALUES('7', 'zhangle', '23', '3');
INSERT INTO `emp` VALUES('8', 'qingtian', '38', '3');
INSERT INTO `emp` VALUES('9', 'xiayutian', '36', '2');
INSERT INTO `emp` VALUES('10', 'fangjia', '40', '1');
Copier après la connexion
Scénario analyse

1. Rejoindre gauche (rejoindre gauche )

A's unique + AB's public

SELECT * from emp e LEFT JOIN dept d ON e.dept_id=d.dept_id;
Copier après la connexion

Comment utiliser JOIN dans MySQL

2. 3. Jointure interne (jointure interne )

AB's public

SELECT * from emp e RIGHT JOIN dept d ON e.dept_id=d.dept_id;
Copier après la connexion
Comment utiliser JOIN dans MySQL

4. (jointure à droite et table à gauche =null)

B's unique

SELECT * from emp e INNER JOIN dept d ON e.dept_id=d.dept_id;
Copier après la connexion
Comment utiliser JOIN dans MySQL

6. Jointure externe complète

A's unique + B's unique + AB's public

Comment utiliser JOIN dans MySQL

Remarque : MySQL ne prend pas en charge FULL OUTER JOIN (support ed dans ORACLE).

Utilisez donc UNION pour l'implémenter, qui peut **fusionner + supprimer la duplication**

Scénario d'application :

Les résultats à interroger proviennent de plusieurs tables, et les multiples tables n'ont pas de relation de connexion directe, mais Lorsque les informations de la requête sont cohérentesComment utiliser JOIN dans MySQL

Caractéristiques :

1. Le nombre de colonnes de requête qui nécessitent plusieurs instructions de requête est le même

2. Le type et l'ordre de chaque colonne de la requête qui nécessite plusieurs instructions de requête sont les mêmes. le meilleur. Cohérent

3. Le mot-clé union ** est dédupliqué par défaut

Si vous utilisez
union all, il peut contenir des doublons**

SELECT * from emp e LEFT JOIN dept d ON e.dept_id=d.dept_id WHERE d.dept_id is null;
Copier après la connexion

7. tables gauche et droite = null)

Exclusivité A + exclusivité B

SELECT * from emp e RIGHT JOIN dept d ON e.dept_id=d.dept_id WHERE e.dept_id is null;
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!

Étiquettes associées:
source:yisu.com
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal