MySQL七種JOIN類型小結(jié)
更新時間:2021年10月22日 09:50:40 作者:IllTamer
今天給大家介紹MySQL七種JOIN類型詳解,本文通過sql語句給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
在開始之前,我們創(chuàng)建兩個表用于演示將要介紹的其中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;
初始化數(shù)據(jù)


七種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表數(shù)據(jù)

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類型內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
MYSQL跨服務器同步數(shù)據(jù)經(jīng)驗分享
這篇文章主要介紹了MYSQL跨服務器同步數(shù)據(jù)詳細過程,需要的朋友可以參考下2014-03-03

