SQL基礎介紹—關聯(lián)查詢

SQL基礎介紹—關聯(lián)查詢

前面,我們介紹的都是單表查詢(就是只從一張表中獲取數(shù)據(jù)),而實際應用的時候,我們都會同時查詢多張表,這里,我們就介紹下,多表關聯(lián)查詢的使用。

SQL join 用于根據(jù)兩個或多個表中的列之間的關系,從這些表中查詢數(shù)據(jù)

關聯(lián)查詢.png

前置知識

主鍵(Primary Key):可以唯一確定一條記錄的字段,比如學生表中的學生ID,生活中我們的身份證號
外鍵(Foreign Key):指向另一張表的主鍵,比如學生表中的班級ID,班級ID是班級表中的主鍵,但在學生表中是外鍵

主鍵和外鍵可以在建表的時候指定,他可以在數(shù)據(jù)庫層面,控制你的數(shù)據(jù)的完整性、一致性。

inner join

inner join 可以簡寫為 join,結(jié)果集是兩張表中 都存在的記錄,是一個交集,詳情參考上面的圖片。
比如:在學生表中,有一個班級ID,我們想根據(jù)班級ID,在班級表中找到班級信息

select 
    *
from 
    t_student a 
-- 要關聯(lián)查詢的表
join 
    t_class b 
-- 使用什么字段去關聯(lián)這兩張表
on 
    a.c_id = b.c_id
;

join

left join

左關聯(lián),以左邊的表為主表,不管外鍵在右表中是否存在,左表的數(shù)據(jù)都會存在。
比如學生表中,有這樣一條記錄,他的班級ID是904,但是班級表中并沒有904的班級信息,
所以,使用join的話是查不到這條記錄的

-- 2. left join 
-- 學生表為主表,包含所有學生信息
select 
    *
from 
    t_student a 
left join 
    t_class b 
on 
    a.c_id = b.c_id
;
left join

right join

右關聯(lián),和做關聯(lián)類似,但已右表為主表


-- 3. right join 
-- 班級表為主表,不管改班級是否有學生信息
select 
    *
from 
    t_student a 
right join 
    t_class b 
on 
    a.c_id = b.c_id
;
right join

full outer join

全關聯(lián),mysql沒有full join 語法,我們可以通過使用union來實現(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
;
full join

小結(jié)

關聯(lián)查詢的話,我們主要是選擇好主表,然后找好表與表之間的關聯(lián)關系,注意多對多、一對多的這種關系,驗證號結(jié)果數(shù)據(jù)就行了。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容