天天看點

left join on多表關聯_MySQL-關聯查詢

MySQL-關聯查詢

SQL資料分析 1周前

MySQL

關聯查詢

前面,我們介紹的都是單表查詢(就是隻從一張表中擷取資料),而實際應用的時候,我們都會同時查詢多張表,這裡,我們就介紹下,多表關聯查詢的使用。

SQL join 用于根據兩個或多個表中的列之間的關系,從這些表中查詢資料

left join on多表關聯_MySQL-關聯查詢
前置知識

主鍵(Primary Key):可以唯一确定一條記錄的字段,比如學生表中的學生ID,生活中我們的身份證号

外鍵(Foreign Key):指向另一張表的主鍵,比如學生表中的班級ID,班級ID是班級表中的主鍵,但在學生表中是外鍵

主鍵和外鍵可以在建表的時候指定,他可以在資料庫層面,控制你的資料的完整性、一緻性。

測試資料參考:http://yuguiyang.github.io/2017/09/09/mysql-handbook-01/

inner join

inner join 可以簡寫為 join,結果集是兩張表中

都存在的記錄

,是一個交集,詳情參考上面的圖檔。

比如:在學生表中,有一個班級ID,我們想根據班級ID,在班級表中找到班級資訊

select

*

from

t_student a

-- 要關聯查詢的表

join

t_class b

-- 使用什麼字段去關聯這兩張表

on

a.c_id = b.c_id

;

left join on多表關聯_MySQL-關聯查詢
left join

左關聯,以左邊的表為主表,不管外鍵在右表中是否存在,左表的資料都會存在。

比如學生表中,有這樣一條記錄,他的班級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 on多表關聯_MySQL-關聯查詢
right join

右關聯,和做關聯類似,但已右表為主表

-- 3. right join

-- 班級表為主表,不管改班級是否有學生資訊

select

*

from

t_student a

right join

t_class b

on

a.c_id = b.c_id

;

left join on多表關聯_MySQL-關聯查詢
full outer join

全關聯,mysql沒有full join 文法,我們可以通過使用union來實作

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

;

left join on多表關聯_MySQL-關聯查詢
cross join

cross join 是對2個表做笛卡爾積

select *from t_class a

cross join t_class b

order by a.c_id,b.c_id

;

小結

關聯查詢的話,我們主要是選擇好主表,然後找好表與表之間的關聯關系,注意多對多、一對多的這種關系,驗證号結果資料就行了。