当前位置:8288分类目录 » 站长资讯 » 编程 » 文章详细

SQL join区别

来源:网络转载 浏览:42139次 时间:2023-09-02

首先创建需要JOIN的两个表:

CREATE TABLE `tbl_emp` (
   `id` INT(11) NOT NULL AUTO_INCREMENT,
   `name` VARCHAR(30) DEFAULT NULL,
   `deptID` VARCHAR(40) DEFAULT NULL,
   PRIMARY KEY (`id`)
) ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

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;

我们可以看到数据的呈现:



1、A ∩ B



SELECT *
 FROM tbl_emp a
 INNER JOIN tbl_dept b # 共有
 ON a.deptID = b.ID



2、A ( = A ∩ B + A* )



SELECT *
 FROM tbl_emp a
 LEFT JOIN tbl_dept b
 ON a.deptID = b.ID



3、B ( = A ∩ B + B* )



SELECT *
 FROM tbl_emp a
 RIGHT JOIN tbl_dept b
 ON a.deptID = b.ID



4. A* ( = A - A ∩ B )



SELECT *
 FROM tbl_emp a
 LEFT JOIN tbl_dept b 
 ON a.deptID = b.ID # ON时主表保留
 WHERE B.ID IS NULL # 筛选A表数据



5. B* ( = B - A ∩ B )



SELECT *
 FROM tbl_emp a
 RIGHT JOIN tbl_dept b 
 ON a.deptID = b.ID # ON时主表保留
 WHERE a.deptID IS NULL # 筛选B表数据



6. A ∪ B



SELECT < select_list >
 FROM TableA A
 FULL OUTER JOIN TableB B ## FULL OUTER 仅oracle支持
 ON A.Key = B.Key


-- MySQL格式
 SELECT *
 FROM tbl_emp a
 LEFT JOIN tbl_dept b 
 ON a.deptID = b.ID 
 UNION
 SELECT *
 FROM tbl_emp a
 RIGHT JOIN tbl_dept b 
 ON a.deptID = b.ID



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格式
 SELECT *
 FROM tbl_emp a
 LEFT JOIN tbl_dept b 
 ON a.deptID = b.ID 
 UNION
 SELECT *
 FROM tbl_emp a
 RIGHT JOIN tbl_dept b 
 ON a.deptID = b.ID
 WHERE a.deptID IS NULL OR b.ID IS NULL



作者:九道门聊数据
链接:https://www.zhihu.com/question/486152274/answer/2300115455
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。



8288分类目录声明:本站部分文章来源于网络,版权属于原作者所有。如有转载或引用文章/图片涉及版权问题,请联系我们处理.我们将在第一时间删除! 联系邮箱:tsk@qq.com

推荐网站

最新加入网站 TOP5

入站排行榜 TOP5