MySQL筆記3——內連線/外連線、多表連線

¹²₃₄發表於2020-12-16


在這裡插入圖片描述

一、內連線

1、等值連線

* 特點:條件為等量關係

# 語法
select 
	別名1.欄位,別名2.欄位
from1 別名1
join2 別名2
on
	連線條件
where
	其他條件

案例:查詢每個員工的員工名字和部門名字
在這裡插入圖片描述
案例:查詢每個員工的員工名字、員工編號和部門名字、工作地點

select
	e.empno,e.ename,p.pname,p.loc
from 
	emp e
join
	dept d
on 
	e.deptno=d.deptno;#兩張表之間的連線關係就是他們的deptno欄位相等,等值連線

在這裡插入圖片描述

2、非等值連線

  • 特點:連線條件中的關係為非等量關係
    示例:現有如下兩張表,找出每個員工的薪資等級,要求顯示員工名、工資、工資等級
    在這裡插入圖片描述
select
	e.ename,e.sal,s.grade
from emp e
join salgroud s
on
	e.sal between s.losal and s.hisal;
	# 條件為:e表中的sal(工資)欄位介於s表中losal欄位和hisal欄位之間
	# 條件為非等量關係,因此成非等值連線

在這裡插入圖片描述

3、自連線

  • 特點:一張表看做兩張表,自己連線自己
    示例:現有下表,找出每個員工的上級領導,要求顯示員工名和領導名
    在這裡插入圖片描述
    員工的領導編號=領導的員工編號。因為領導也是員工,在員工表中。
    因此連線條件為:員工表的領導編號=領導表的員工編號
select
	a.ename as '員工',b.ename as '領導'
from
	emp a	#emp表起別名a看成員工表
join
	emp b	#emp表起別名b看成領導表
on
	a.mgr=b.empno;	
	#條件:員工表的領導編號=領導表的員工編號
#這種把一張表看成兩張表的連線方式成為自連線

在這裡插入圖片描述
上面的查詢由於KING員工是大BOSS上面已經沒領導了,KING的MGR欄位為NULL。因此上述語句匹配時沒有匹配到,丟失了KING的資料。下面介紹使用外連線查詢時如何全部查出。

二、外連線

  • 內連線:假設A表和B表進行連線,使用內連線的話,凡是A表和B表能夠匹配上的記錄都查詢出來,這就是外連線。A、B兩張表無主副之分,兩張表是平等的。
  • 外連線:假設A表和B表進行連線,使用外連線的話,AB兩張表中有一張是主表,一張表是副表。在查詢時主要查詢主表中的資料,附帶著查詢副表,當副表中的資料沒有和主表中的資料匹配上時,副表自動模擬出NULL與之匹配

外連線最重要的特點是:主表中的資料能完整的全部查出,不會導致資料的丟失

①左外連線

任何一個左連線都有一個右連線的寫法,同樣任何一個右連線都有一個左連線的寫法

左邊的表是主表

#語法,只要在join關鍵字前加left,代表join左邊的表是主表,右邊的表是副表
select 
	別名1.欄位,別名2.欄位
from1 別名1
left join2 別名2
on
	連線條件
where
	其他條件

示例:還是上面的示例,查詢所有員工的領導。在使用內連線的時候,由於KING的領導為NULL,因此匹配條件不滿足,導致匹配結果中沒有KING。下面看使用左外連線如何查詢出全部員工的領導

select
	a.ename,b.ename
from emp a
left join emp b
on a.mgr=b.empno;	
# 語法和使用內連線的時候基本一樣,只是在join前面加了left
# 加了left後表示a表是主表,b表是副表。在查詢時要對a表中
# 要查詢的欄位全部顯示出來,即使匹配條件可能不滿足,但是a表中
# 要查詢的欄位也要顯示,而b表中不滿足匹配條件的模擬出NULL與之匹配

在這裡插入圖片描述
KIING在a表中的MGR(欄位)在執行匹配條件時找不到b表中與之對應的EMPNO欄位。因此副表b會模擬出一個NULL值與a表中KING的MGR欄位匹配,最終滿足條件顯示

②右外連結

右邊的表是主表
還是上面的例子,使用右外連線

select
	a.ename,b.ename
from emp b
right join emp a
on a.mgr=b.empno;
# 右連線時,join右邊的表為主編,即a表變成主表,b表為副表。KIING在a表中的
# MGR(欄位)在執行匹配條件時找不到b表中與之對應的EMPNO欄位。因此副表b會模擬
# 出一個NULL值與a表中KING的MGR欄位匹配,最終滿足條件顯示

示例:查詢那個部門下沒有員工
在這裡插入圖片描述
通過表可知40部門下沒員工可是怎麼查詢出呢

select 
	a.*,b.*
from dept a
left join emp b
on a.mgr=b.empno;
查詢結果如下圖

在這裡插入圖片描述
在加過濾條件即可篩選出資料了

select a.*,b.*
from dept a
left join emp b
on a.mgr=b.empno;
where b.ename(或者empno/job/mgr等欄位) is null;

在這裡插入圖片描述
在把emp表中的欄位不顯示即可

最終查詢程式碼
select a.*
from dept a
left join emp b
on a.mgr=b.empno;
where b.ename(或者empno/job/mgr等欄位) is null;

在這裡插入圖片描述

③全連線

不用,用的少

三、多張表連線

select
	欄位
from
	A表
join 
	B表
on
	A表和B表之間的連線關係
join
	C表
on
	A表、B表連線之後新表和C表之間的連線關係
join
	……
on
	……

示例:找出每個員工的部門名稱和工資等級

在這裡插入圖片描述

select 
	e.ename '姓名',d.dname '部門名稱',s.grade '工資等級' 
from emp e 
join dept d 
on 
	e.deptno=d.deptno 
join salgrade s 
on 
	e.sal between s.losal and s.hisal;

在這裡插入圖片描述
示例:找出每個員工所在的部門名稱、薪資等級、上級領導

select
    e.ename,d.dname,s.grade,e1.ename 
from 
    emp e 
join 
    dept d 
on  
    e.deptno=d.deptno 
join 
    salgrade s 
on 
    e.sal between s.losal and s.hisal 
left join   #e表是主表,e1是副表,主表中的mgr欄位不等於副表的empno欄位時,副表自動模擬出一個NULL值與之匹配   
    emp e1 
on  
    e.mgr=e1.empn

在這裡插入圖片描述

相關文章