mysql join的用法? 说一说MySQL的7种join操作
【死记硬背】
MySQL的7种join操作分别是:内连接(inner join)、左连接(left join)、右连接(right join)、外连接(outer join)、左内连接(left join excluding inner join)、右内连接(right join excluding inner join)、外内连接(outer join excluding inner join)。
下面进行实际操作来看下这7种join的操作结果。
1 SQL准备
CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 4 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
INSERT INTO `user` VALUES (1, '张三');
INSERT INTO `user` VALUES (2, '李四');
INSERT INTO `user` VALUES (3, '王二');
CREATE TABLE `user2` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 4 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
INSERT INTO `user2` VALUES (1, '张三');
INSERT INTO `user2` VALUES (2, '李四');
INSERT INTO `user2` VALUES (4, '麻子');
2 inner join(内连接)
data:image/s3,"s3://crabby-images/ec3f5/ec3f57ebff311432ee251217ee37355c4ced49ad" alt=""
select a.id,a.name from user a inner join user2 b on a.id=b.id;
3 left join(左连接)
data:image/s3,"s3://crabby-images/ca1a3/ca1a3b46c8be0d9ddbaf8e95b822249294919a53" alt=""
select a.id,a.name from user a left join user2 b on a.id=b.id;
4 right join(右连接)
data:image/s3,"s3://crabby-images/c37c7/c37c7bdbfb460276afceeb317bc170e27a813405" alt=""
select b.id,b.name from user a right join user2 b on a.id=b.id;
5 outer join(外连接)
data:image/s3,"s3://crabby-images/1a513/1a513081a7b364aaf18369530118ee1a6d77e15b" alt=""
select a.id,a.name from user a left join user2 b on a.id=b.id union select b.id,b.name from user a right join user2 b on a.id=b.id;
6 left join excluding inner join(左内连接)
data:image/s3,"s3://crabby-images/b1e50/b1e50ec4f5fdd8a923c01d086c22a2aa64b36ffd" alt=""
select a.id,a.name from user a left join user2 b on a.id=b.id where b.id is null;
7 right join excluding inner join(右内连接)
data:image/s3,"s3://crabby-images/94953/94953a0d643905d7d4fb416db3685ed96b642107" alt=""
select b.id,b.name from user a right join user2 b on a.id=b.id where a.id is null;
8 outer join excluding inner join(外内连接)
data:image/s3,"s3://crabby-images/a3cf0/a3cf0ae35a4ddb9045cf86276d1f7189f69c4b95" alt=""
select a.id,a.name from user a left join user2 b on a.id=b.id where b.id is null
union
select b.id,b.name from user a right join user2 b on a.id=b.id where a.id is null;
相关推荐
-
PHP8种变量类型的详细讲解2025-02-22 00:32:24
-
php+apache 和 php+nginx的区别2025-02-22 00:21:27
-
PHP:与workerman结合实现定时任务2025-02-22 00:15:57
-
Nginx的Rewrite规则与实例2025-02-22 00:15:39
-
MySql中身份证字段的简单脱敏介绍2025-02-22 00:15:36