Maison >base de données >tutoriel mysql >Comment utiliser JOIN dans MySQL

Comment utiliser JOIN dans MySQL

WBOY
WBOYavant
2023-06-03 09:30:351558parcourir

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');

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');
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;

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;
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;
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;

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;

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:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer