首頁  >  文章  >  資料庫  >  mysql left join的基本用法及on與where的差別是什麼

mysql left join的基本用法及on與where的差別是什麼

WBOY
WBOY轉載
2023-06-02 23:54:361666瀏覽

前言

我們在寫sql語句的時候,總是無法避免使用到連接關鍵字,例如內連接、外連接。種類是很多的,我在這裡貼上一張在別處找到的圖:

mysql left join的基本用法及on與where的差別是什麼

#這張圖我認為是非常詳細了,它顯示出了SQL語句中常見的連結類型,以本文中的left join為例,網路上是這麼給定義的:LEFT JOIN 關鍵字會從左表傳回所有的行,即使在右表中沒有符合的行。

其實光從字面意思上來說的話,left join是比較好理解的,但是在使用的過程中,還是會有一些問題的,比如條件在on後面與在where後面,他們的結果是完全不一樣的,接下來我們就從淺到深去了解下left join。

實例

CREATE TABLE `class` (
  `class_id` int NOT NULL,
  `class_name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
  `class_grade` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
  PRIMARY KEY (`class_id`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 ROW_FORMAT=COMPACT;

score表:

CREATE TABLE `score` (
  `class_id` int NOT NULL,
  `stu_id` varchar(11) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
  `score` int DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 ROW_FORMAT=COMPACT;

他們各有資料:

mysql left join的基本用法及on與where的差別是什麼

mysql left join的基本用法及on與where的差別是什麼

##Q1:select c.class_id,c.class_name,c.class_grade,s.stu_id,s.score from class c left join score s on c.class_id=s.class_id。

這句話可以重寫為:我們分析了這個語句,左表是class表,右表是score表,它們的關聯欄位是class_id。當左表class_id為1時,右表有兩條記錄的class_id為1;當左表class_id為2時,右表有兩條記錄的class_id為2;當左表class_id為3時,右表有一條記錄的class_id為3,所以我們要得到五筆記錄:

1	语文	A	A002	82
1	语文	A	A001	91
2	数学	B	A002	87
2	数学	B	A001	95
3	英语	C	B003	65

Q2:select c.class_id,c.class_name,c.class_grade,s.stu_id,s.score from class c left join score s on c.class_id=s.class_id and s.score=90。

以第一題的例子為基礎,這個又多了個s.score=90的條件,這個表示右表score的score字段為90,但是我們看表的數據,發現右表沒有score為90 ,ok,那結果會不會是空呢?畢竟右表是沒有符合條件的數據的。

事實上,如果執行這條sql語句的話,最終是可以得到結果的,只不過只會得到三條數據,左表中的字段全部顯示,右表中的字段全部對應為空,這是因為右邊表格中沒有記錄的score是90,所以右邊表格的欄位才是空的。

on是先將資料過濾,然後再進行連接,而where是在兩表進行關聯查詢之後,再進行過濾的,on與where的區別就在這裡,之後的例子也會涉及這兩個區別的。

1	语文	A		
2	数学	B		
3	英语	C

Q3:select c.class_id,c.class_name,c.class_grade,s.stu_id,s.score from class c left join score s on c.class_id=s.class_id where c.class_name=&lsquo ;語文’ and s.score=90。

要注意where和on的不同,因為這個語句牽涉到了where關鍵字。這個sql的查詢結果為空,這是因為先將兩個表連接查詢出結果,然後再過濾,而連表查詢出的結果是沒有記錄符合class_name=‘語文’,並且score=90,所以查詢結果為空。

Q4:select c.class_id,c.class_name,c.class_grade,s.stu_id,s.score from class c left join score s on c.class_id=s.class_id and 1=0。

我們有時會在sql的where條件後面加上1=1,而這裡的1=0則是表示兩表關聯失敗,所以這個的結果只會顯示出左表的資料。

1	语文	A	null	null
2	数学	B	null	null
3	英语	C	null	null

Q5:select c.class_id,c.class_name,c.class_grade,s.stu_id,s.score from class c left join score s on 1=0。

這個與上面的sql語句的執行結果是一樣的,其實都是將左表的內容全部顯示。

1	语文	A	null	null
2	数学	B	null	null
3	英语	C	null	null

Q6:select c.class_id,c.class_name,c.class_grade,s.stu_id,s.score from class c left join score s on c.class_id=s.class_id and c.class_name=&lsquo s on c.class_id=s.class_id and c.class_name=&lsquo ;語文’。

這個需要在右表中過濾出class_name為語文的記錄,有兩條,然後左表去連接這兩條記錄,所以不難看出,有四條結果:

1	语文	A	A002	82
1	语文	A	A001	91
2	数学	B	null	null
3	英语	C	null	null

Q7:select c.class_id,c.class_name,c.class_grade,s.stu_id,s.score from class c left join score s on c.class_id=s.class_id and c.class_name=‘英文’。

分析同上一題(空白的地方的結果為null):

1	语文	A		
2	数学	B		
3	英语	C	B003	65

Q8:select c.class_id,c.class_name,c.class_grade,s.stu_id,s.score from class c left join score s on c.class_id=s.class_id and c.class_name=‘體育’。

右表中是沒有數據的class_name為體育的,所以右表為空,顯示左表的全部數據,右表對應的欄位為空:

1	语文	A		
2	数学	B		
3	英语	C

Q9:select c .class_id,c.class_name,c.class_grade,s.stu_id,s.score from class c left join score s on c.class_id=s.class_id and c.class_name=‘語文’ and s.score=91。

右表中只有一条记录的score为91,所以需要拿左表与右表的这一条数据进行关联,左表只有语文可以与右表的那一条数据对上,所以结果为:

1	语文	A	A001	91
2	数学	B		
3	英语	C

Q10:select c.class_id,c.class_name,c.class_grade,s.stu_id,s.score from class c left join score s on c.class_id=s.class_id and c.class_name=‘体育’ and s.score=90。

右表中没有数据的score为90,同样左表中也没有class_name为体育,但是这并不意味着最后的结果就是空了,只要没有where条件,最终的结果数量最起码也会是左表中原先的数据数量,所以这条sql会返回左表的全部数据。

1	语文	A		
2	数学	B		
3	英语	C

Q11:select c.class_id,c.class_name,c.class_grade,s.stu_id,s.score from class c left join score s on c.class_id=s.class_id where c.class_name=‘英语’。

需要注意的点:条件是在where中的,也就是在表关联之后,再进行过滤的,所以最终的结果只会有一条:

3	英语	C	B003	65

Q12:select c.class_id,c.class_name,c.class_grade,s.stu_id,s.score from class c left join score s on c.class_id=s.class_id where s.score=91。

和上面一样,是在连表查询之后,找出score=90的数据:

1	语文	A	A001	91

Q12;select c.class_id,c.class_name,c.class_grade,s.stu_id,s.score from class c left join score s on c.class_id=s.class_id where c.class_name=‘语文’ and s.score=91。

我们将两表连接查询后,找出结果中class_name为语文,score为91的记录,只有一条:

1	语文	A	A001	91

以上是mysql left join的基本用法及on與where的差別是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除