MySQL七种JOIN类型小结
短信预约 -IT技能 免费直播动态提醒
在开始之前,我们创建两个表用于演示将要介绍的其中JOIN类型。
建表
CREATE TABLE `tbl_dept` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`deptName` VARCHAR(30) DEFAULT NULL,
`locAdd` VARCHAR(40) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
CREATE TABLE `tbl_emp` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`name` VARCHAR(20) DEFAULT NULL,
`deptId` VARCHAR(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `fk_dept_id` (`deptId`)
) ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
初始化数据
七种JOIN
1. A ∩ B
SELECT < select_list >
FROM TableA A
INNER JOIN TableB B # 共有
ON A.Key = B.Key
2. A ( = A ∩ B + A* )
SELECT < select_list >
FROM TableA A
LEFT JOIN TableB B
ON A.Key = B.Key
3. B ( = A ∩ B + B* )
SELECT < select_list >
FROM TableA A
RIGHT JOIN TableB B
ON A.Key = B.Key
4. A* ( = A - A ∩ B )
SELECT < select_list >
FROM TableA A
LEFT JOIN TableB B
ON A.Key = B.Key # ON时主表保留
WHERE B.Key IS NULL # 筛选A表数据
5. B* ( = B - A ∩ B )
SELECT < select_list >
FROM TableA A
RIGHT JOIN TableB B
ON A.Key = B.Key
WHERE A.Key IS NULL
6. A ∪ B
SELECT < select_list >
FROM TableA A
FULL OUTER JOIN TableB B ## FULL OUTER 仅oracle支持
ON A.Key = B.Key
7. A ∪ B - A ∩ B
SELECT < select_list >
FROM TableA A
FULL OUTER JOIN TableB B
ON A.Key = B.Key
WHERE A.Key IS NULL OR B.Key IS NULL
到此这篇关于MySQL七种JOIN类型详解的文章就介绍到这了,更多相关mysql join类型内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341