日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

mysql left join的基本用法以及on與where的區(qū)別

瀏覽:306日期:2023-05-05 10:11:54

前言

我們?cè)趯憇ql語句的時(shí)候,總是無法避免使用到連接關(guān)鍵詞,比如內(nèi)連接、外連接。種類是很多的,我在這里貼上一張?jiān)趧e處找到的圖:

這張圖我認(rèn)為是非常詳細(xì)了,它展示出了SQL語句中常見的鏈接類型,以本文中的left join為例,網(wǎng)上是這么給定義的:LEFT JOIN 關(guān)鍵字會(huì)從左表 那里返回所有的行,即使在右表中沒有匹配的行。

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

實(shí)例

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;

他們各有數(shù)據(jù):

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。

我們對(duì)這個(gè)語句進(jìn)行分析:左表是class表,右表是score表,兩表的class_id為兩表關(guān)聯(lián)字段。當(dāng)左表class_id為1時(shí),右表有兩條記錄的class_id為1;當(dāng)左表class_id為2時(shí),右表有兩條記錄的class_id為2;當(dāng)左表class_id為3時(shí),右表有一條記錄的class_id為3,所以我們應(yīng)當(dāng)?shù)玫轿鍡l記錄:

1	語文	A	A002	821	語文	A	A001	912	數(shù)學(xué)	B	A002	872	數(shù)學(xué)	B	A001	953	英語	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。
以第一題的例子為基礎(chǔ),這個(gè)又多了個(gè)s.score=90的條件,這個(gè)表示右表score的score字段為90,但是我們看表的數(shù)據(jù),發(fā)現(xiàn)右表沒有score為90,ok,那結(jié)果會(huì)不會(huì)是空呢?畢竟右表是沒有符合條件的數(shù)據(jù)的。

事實(shí)上,如果執(zhí)行這條sql語句的話,最終是可以得到結(jié)果的,只不過只會(huì)得到三條數(shù)據(jù),左表中的字段全部顯示,右表中的字段全部對(duì)應(yīng)為空,這是因?yàn)橛冶碇袥]有記錄的score是90,所以右表的字段才是空的。

on是先對(duì)數(shù)據(jù)進(jìn)行過濾,然后再進(jìn)行連接,而where是在兩表進(jìn)行關(guān)聯(lián)查詢之后,再進(jìn)行過濾的,on與where的區(qū)別就在這里,之后的例子也會(huì)涉及這兩個(gè)區(qū)別的。

1	語文	A		2	數(shù)學(xué)	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。

這個(gè)語句里面就涉及到了where關(guān)鍵字了,因此是需要注意與on的不同。這個(gè)sql的查詢結(jié)果為空,這是因?yàn)橄葘杀磉B接查詢出結(jié)果,然后再進(jìn)行過濾,而連表查詢出的結(jié)果是沒有記錄符合class_name=‘語文’,并且score=90,所以查詢結(jié)果為空。

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。

我們有時(shí)在sql的where條件后面會(huì)加上1=1,而這里的1=0則是表示兩表關(guān)聯(lián)失敗,所以這個(gè)的結(jié)果只會(huì)顯示出左表的數(shù)據(jù)。

1	語文	A	null	null2	數(shù)學(xué)	B	null	null3	英語	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。

這個(gè)與上面的sql語句的執(zhí)行結(jié)果是一樣的,其實(shí)都是將左表的內(nèi)容全部顯示。

1	語文	A	null	null2	數(shù)學(xué)	B	null	null3	英語	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=‘語文’。

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

1	語文	A	A002	821	語文	A	A001	912	數(shù)學(xué)	B	null	null3	英語	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=‘英語’。

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

1	語文	A		2	數(shù)學(xué)	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=‘體育’。

右表中是沒有數(shù)據(jù)的class_name為體育的,所以右表為空,顯示左表的全部數(shù)據(jù),右表對(duì)應(yīng)的字段為空:

1	語文	A		2	數(shù)學(xué)	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,所以需要拿左表與右表的這一條數(shù)據(jù)進(jìn)行關(guān)聯(lián),左表只有語文可以與右表的那一條數(shù)據(jù)對(duì)上,所以結(jié)果為:

1	語文	A	A001	912	數(shù)學(xué)	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。

右表中沒有數(shù)據(jù)的score為90,同樣左表中也沒有class_name為體育,但是這并不意味著最后的結(jié)果就是空了,只要沒有where條件,最終的結(jié)果數(shù)量最起碼也會(huì)是左表中原先的數(shù)據(jù)數(shù)量,所以這條sql會(huì)返回左表的全部數(shù)據(jù)。

1	語文	A		2	數(shù)學(xué)	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=‘英語’。

需要注意的點(diǎn):條件是在where中的,也就是在表關(guān)聯(lián)之后,再進(jìn)行過濾的,所以最終的結(jié)果只會(huì)有一條:

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的數(shù)據(jù):

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。

我們將兩表連接查詢后,找出結(jié)果中class_name為語文,score為91的記錄,只有一條:

1	語文	A	A001	91

總結(jié)

通過這12道sql語句,其實(shí)就可以基本上掌握left join的使用以及可能出現(xiàn)的場景了,尤其是on與where在執(zhí)行sql語句時(shí),條件位置不同,最終的結(jié)果也不大相同。我覺得需要記住,只要沒有where條件,那么最終結(jié)果的數(shù)量最起碼與左表的數(shù)據(jù)數(shù)量相同,不可能會(huì)出現(xiàn)最終的結(jié)果為空的情況。

標(biāo)簽: MySQL
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
福利视频一区| 国产精品一级| 日韩国产欧美| 精品国产a一区二区三区v免费| 国产精品中文字幕制服诱惑| 日韩av中文在线观看| 久久香蕉精品| 黄色成人精品网站| 欧美精品一区二区三区精品| 91精品福利| 亚洲一区二区三区高清| 视频福利一区| 亚洲手机在线| 日韩一级网站| 亚洲精品综合| 欧美一级二级视频| 国产激情一区| 综合日韩av| 五月天激情综合网| 性色一区二区| 日韩二区三区在线观看| 国产九九精品| 国产一区2区在线观看| 亚洲欧洲高清| 欧美日韩精品一本二本三本 | 久久精品国产在热久久| 久久中文字幕一区二区三区| 欧美国产美女| 一区二区亚洲精品| 四虎精品永久免费| 久久精品国产99国产| 成人免费网站www网站高清| 欧美日韩国产免费观看视频| 视频一区视频二区中文字幕| 欧美日韩视频免费看| 精品久久影院| 亚洲国产成人精品女人| 久久亚洲欧洲| 国产精品红桃| 日韩一区电影| 亚洲色图国产| 久久精品国产精品亚洲毛片| 亚洲成av人片一区二区密柚| 综合国产视频| 97国产成人高清在线观看| 1024精品一区二区三区| 日韩精品一区二区三区免费视频| 精品国产美女a久久9999| 欧洲毛片在线视频免费观看| 日本在线不卡视频| 伊人久久av| 亚洲资源网站| 午夜久久中文| 中文字幕日本一区| 98精品久久久久久久| 午夜亚洲一区| 精品免费av| 中文视频一区| 天堂а√在线最新版中文在线| 蜜桃视频第一区免费观看| 精品日产乱码久久久久久仙踪林| 日韩一区二区久久| 国产成人精品一区二区免费看京| 久久国产精品毛片| 国产一区福利| 亚洲1区在线观看| 成人日韩精品| 欧美日本三区| 久久免费大视频| 日韩国产欧美三级| 伊人久久在线| 热久久久久久| 日韩国产欧美| 五月天综合网站| 国产精品成人国产| 日韩1区2区日韩1区2区| 国产亚洲一区二区三区不卡 | 中文字幕日韩亚洲| 国产专区精品| 老鸭窝一区二区久久精品| 91九色综合| 亚洲午夜一级| 久久国产三级| 日本在线不卡视频| 国产成人精品亚洲线观看| 麻豆一区在线| 亚洲欧洲国产精品一区| 久久精品欧美一区| 国产精久久久| 亚洲人成在线影院| 激情婷婷综合| 亚洲黄色中文字幕| 国产精品久久久久久久久久久久久久久 | 精品资源在线| 日韩欧美中文字幕在线视频| 欧美在线亚洲综合一区| 不卡专区在线| 精品亚洲二区| 欧美亚洲网站| 日韩一区二区三区精品| 夜久久久久久| 欧美亚洲国产精品久久| 91一区二区三区四区| 精品网站aaa| 国产日韩欧美一区在线| 亚洲+小说+欧美+激情+另类| 久久久精品久久久久久96 | 国产欧美日韩一区二区三区四区| 男人的天堂久久精品| 五月精品视频| 亚洲国产一区二区三区在线播放 | 国产高清一区| 少妇精品导航| 99久久99视频只有精品| 伊人久久av| 欧美aa一级| 日韩深夜视频| 中文字幕一区久| 精品视频99| 久久精品系列| 色婷婷精品视频| 亚洲人成精品久久久| 美女视频一区在线观看| 日本国产亚洲| 日韩精品91亚洲二区在线观看| 最新国产精品视频| 亚洲深夜福利在线观看| 美女久久一区| 免费成人av在线播放| 亚洲一区av| 中文字幕一区二区三区在线视频| 日韩在线卡一卡二| 一本一道久久a久久| 丝瓜av网站精品一区二区 | 久久国产精品久久久久久电车| 日韩精品一区第一页| 免费视频一区二区| 亚州av日韩av| 国产精品115| 在线人成日本视频| 色婷婷精品视频| 国产精品日本| 日本中文字幕不卡| 国产精品久久久久9999高清| 精品99久久| 91精品一区二区三区综合| 亚洲www啪成人一区二区| 欧美午夜精彩| 亚洲精品第一| 欧美aⅴ一区二区三区视频| 国产一区调教| 亚洲女同中文字幕| 亚洲tv在线| 国产在视频一区二区三区吞精| 中文另类视频| 午夜在线精品偷拍| 欧美日韩xxxx| 国产+成+人+亚洲欧洲在线| 99精品视频在线| 综合一区二区三区| 国产精品视频一区二区三区综合| 久久精品国产成人一区二区三区| 欧美三级精品| 香蕉久久夜色精品国产| 日韩激情一二三区| 成人污污视频| 欧美日韩国产精品一区二区亚洲| 日本欧美一区二区在线观看| 激情不卡一区二区三区视频在线| 亚洲精品一区二区妖精| 欧美日本精品| 久久激情网站| 日本一区中文字幕| 日韩国产一区| 日韩国产高清在线| 在线天堂资源www在线污| 91高清一区| 国产精品网址| 波多野结衣一区| 欧美激情视频一区二区三区免费 | 国产精品1区在线| 久久青草久久| 亚洲精选久久| 国产精品久久观看| 在线免费观看亚洲| 国产一区二区精品久| 日韩影院在线观看| 国产白浆在线免费观看| 久久亚洲图片| 国产精品二区不卡| 中文一区一区三区免费在线观| 日本精品黄色| 亚洲欧美专区| 日韩视频网站在线观看| 97se亚洲| 五月天久久777| 国产乱人伦精品一区| 亚洲国产不卡| 国产成人精品一区二区免费看京 | 国产精品视频一区视频二区|