您现在的位置是:网站首页> 编程资料编程资料
MySQL七种JOIN类型小结_Mysql_
2023-05-26
399人已围观
简介 MySQL七种JOIN类型小结_Mysql_
在开始之前,我们创建两个表用于演示将要介绍的其中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类型内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:
相关内容
- MySQL中的引号和反引号的区别与用法详解_Mysql_
- SQL实战演练之网上商城数据库商品类别数据操作_Mysql_
- MySQL中order by的使用详情_Mysql_
- 关于MySQL中的 like操作符详情_Mysql_
- MySQL窗口函数的具体使用_Mysql_
- MySQL中varchar和char类型的区别_Mysql_
- mysql中varchar类型的日期进行比较、排序等操作的实现_Mysql_
- MySQL数据库中varchar类型的数字比较大小的方法_Mysql_
- MySQL和Oracle批量插入SQL的通用写法示例_Mysql_
- MySQL操作符(and、or、in、not)的具体使用_Mysql_
