前面悦污,我們介紹的都是單表查詢(就是只從一張表中獲取數(shù)據(jù))铸屉,而實(shí)際應(yīng)用的時(shí)候,我們都會(huì)同時(shí)查詢多張表切端,這里彻坛,我們就介紹下,多表關(guān)聯(lián)查詢的使用踏枣。
SQL join 用于根據(jù)兩個(gè)或多個(gè)表中的列之間的關(guān)系昌屉,從這些表中查詢數(shù)據(jù)
前置知識(shí)
主鍵(Primary Key):可以唯一確定一條記錄的字段,比如學(xué)生表中的學(xué)生ID茵瀑,生活中我們的身份證號(hào)
外鍵(Foreign Key):指向另一張表的主鍵间驮,比如學(xué)生表中的班級(jí)ID,班級(jí)ID是班級(jí)表中的主鍵马昨,但在學(xué)生表中是外鍵
主鍵和外鍵可以在建表的時(shí)候指定竞帽,他可以在數(shù)據(jù)庫(kù)層面,控制你的數(shù)據(jù)的完整性鸿捧、一致性抢呆。
inner join
inner join 可以簡(jiǎn)寫為 join,結(jié)果集是兩張表中 都存在的記錄笛谦,是一個(gè)交集,詳情參考上面的圖片昌阿。
比如:在學(xué)生表中饥脑,有一個(gè)班級(jí)ID恳邀,我們想根據(jù)班級(jí)ID,在班級(jí)表中找到班級(jí)信息
select
*
from
t_student a
-- 要關(guān)聯(lián)查詢的表
join
t_class b
-- 使用什么字段去關(guān)聯(lián)這兩張表
on
a.c_id = b.c_id
;
left join
左關(guān)聯(lián)灶轰,以左邊的表為主表谣沸,不管外鍵在右表中是否存在,左表的數(shù)據(jù)都會(huì)存在笋颤。
比如學(xué)生表中乳附,有這樣一條記錄,他的班級(jí)ID是904伴澄,但是班級(jí)表中并沒有904的班級(jí)信息赋除,
所以,使用join的話是查不到這條記錄的
-- 2. left join
-- 學(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)類似,但已右表為主表
-- 3. right join
-- 班級(jí)表為主表敞嗡,不管改班級(jí)是否有學(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沒有full join 語法,我們可以通過使用union來實(shí)現(xiàn)
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
;
小結(jié)
關(guān)聯(lián)查詢的話喉悴,我們主要是選擇好主表棱貌,然后找好表與表之間的關(guān)聯(lián)關(guān)系,注意多對(duì)多箕肃、一對(duì)多的這種關(guān)系婚脱,驗(yàn)證號(hào)結(jié)果數(shù)據(jù)就行了。