91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql?left?join的基本用法及on與where的區別是什么

發布時間:2023-05-05 09:55:31 來源:億速云 閱讀:107 作者:iii 欄目:開發技術

這篇文章主要介紹了mysql left join的基本用法及on與where的區別是什么的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇mysql left join的基本用法及on與where的區別是什么文章都會有所收獲,下面我們一起來看看吧。

前言

我們在寫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=‘語文’ and s.score=90。

這個語句里面就涉及到了where關鍵字了,因此是需要注意與on的不同。這個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=‘語文’。

這個需要在右表中過濾出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的區別是什么”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“mysql left join的基本用法及on與where的區別是什么”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

红原县| 噶尔县| 青神县| 南京市| 开江县| 福泉市| 瑞丽市| 梅州市| 泰和县| 读书| 余庆县| 鄂尔多斯市| 科技| 湖北省| 夹江县| 偏关县| 汝州市| 镇雄县| 霍州市| 泰安市| 新龙县| 府谷县| 油尖旺区| 连云港市| 龙南县| 咸丰县| 隆回县| 洪江市| 临安市| 南皮县| 关岭| 贵定县| 于都县| 肥西县| 呼和浩特市| 临江市| 马公市| 会泽县| 蚌埠市| 永昌县| 东乡族自治县|