一、inner join
inner join 可以簡(jiǎn)寫(xiě)為 join,結果集是兩張表中 都存在的記錄,是一個(gè)交集,詳情參考上面的圖片。
比如:在學(xué)生表中,有一個(gè)班級ID,我們想根據班級ID,在班級表中找到班級信息
select
*
from
t_student a
-- 要關(guān)聯(lián)查詢(xún)的表
join
t_class b
-- 使用什么字段去關(guān)聯(lián)這兩張表
on
a.c_id = b.c_id
;
二、left join
左關(guān)聯(lián),以左邊的表為主表,不管外鍵在右表中是否存在,左表的數據都會(huì )存在。
比如學(xué)生表中,有這樣一條記錄,他的班級ID是904,但是班級表中并沒(méi)有904的班級信息,
所以,使用join的話(huà)是查不到這條記錄的
-- 學(xué)生表為主表,包含所有學(xué)生信息
select
*
from
t_student a
left join
t_class b
on
a.c_id = b.c_id
;
三、right join
右關(guān)聯(lián),和做關(guān)聯(lián)類(lèi)似,但已右表為主表
-- 班級表為主表,不管改班級是否有學(xué)生信息
select
*
from
t_student a
right join
t_class b
on
a.c_id = b.c_id
;
四、full outer join
全關(guān)聯(lián),mysql沒(méi)有full join 語(yǔ)法,我們可以通過(guò)使用union來(lái)實(shí)現
select
*
from
t_student a
left join
t_class b
on
a.c_id = b.c_id
UNION
select
*
from
t_student a
right join
t_class b
on
a.c_id = b.c_id
;
五、cross join
cross join 是對2個(gè)表做笛卡爾積
select *from t_class a
cross join t_class b
order by a.c_id,b.c_id
;
關(guān)聯(lián)查詢(xún)的話(huà),我們主要是選擇好主表,然后找好表與表之間的關(guān)聯(lián)關(guān)系,注意多對多、一對多的這種關(guān)系,驗證號結果數據就行了。
本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請
點(diǎn)擊舉報。