电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

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

前言

我們在寫sql語句的時候,總是無法避免使用到連接關(guān)鍵詞,比如內(nèi)連接、外連接。種類是很多的,我在這里貼上一張在別處找到的圖:

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

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

他們各有數(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。

我們對這個語句進行分析:左表是class表,右表是score表,兩表的class_id為兩表關(guān)聯(lián)字段。當(dāng)左表class_id為1時,右表有兩條記錄的class_id為1;當(dāng)左表class_id為2時,右表有兩條記錄的class_id為2;當(dāng)左表class_id為3時,右表有一條記錄的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ǔ),這個又多了個s.score=90的條件,這個表示右表score的score字段為90,但是我們看表的數(shù)據(jù),發(fā)現(xiàn)右表沒有score為90,ok,那結(jié)果會不會是空呢?畢竟右表是沒有符合條件的數(shù)據(jù)的。

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

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

這個語句里面就涉及到了where關(guān)鍵字了,因此是需要注意與on的不同。這個sql的查詢結(jié)果為空,這是因為先將兩表連接查詢出結(jié)果,然后再進行過濾,而連表查詢出的結(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。

我們有時在sql的where條件后面會加上1=1,而這里的1=0則是表示兩表關(guān)聯(lián)失敗,所以這個的結(jié)果只會顯示出左表的數(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。

這個與上面的sql語句的執(zhí)行結(jié)果是一樣的,其實都是將左表的內(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=‘語文’。

這個需要在右表中過濾出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ù),右表對應(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ù)進行關(guān)聯(lián),左表只有語文可以與右表的那一條數(shù)據(jù)對上,所以結(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ù)量最起碼也會是左表中原先的數(shù)據(jù)數(shù)量,所以這條sql會返回左表的全部數(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=‘英語’。

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

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

標(biāo)簽: MySQL
相關(guān)文章:
主站蜘蛛池模板: 沈阳激光机-沈阳喷码机-沈阳光纤激光打标机-沈阳co2激光打标机 | 卫生型双针压力表-高温防腐差压表-安徽康泰电气有限公司 | 天津仓储物流-天津电商云仓-天津云仓一件代发-博程云仓官网 | 游泳池设备安装工程_恒温泳池设备_儿童游泳池设备厂家_游泳池水处理设备-东莞市君达泳池设备有限公司 | 智能案卷柜_卷宗柜_钥匙柜_文件流转柜_装备柜_浙江福源智能科技有限公司 | 陶瓷砂磨机,盘式砂磨机,棒销式砂磨机-无锡市少宏粉体科技有限公司 | 温湿度记录纸_圆盘_横河记录纸|霍尼韦尔记录仪-广州汤米斯机电设备有限公司 | 上海橡胶接头_弹簧减震器_金属软接头厂家-上海淞江集团 | 对夹式止回阀厂家,温州对夹式止回阀制造商--永嘉县润丰阀门有限公司 | 健身器材-健身器材厂家专卖-上海七诚健身器材有限公司 | 不锈钢散热器,冷却翅片管散热器厂家-无锡市烨晟化工装备科技有限公司 | 杭州中策电线|中策电缆|中策电线|杭州中策电缆|杭州中策电缆永通集团有限公司 | 上海小程序开发-小程序制作-上海小程序定制开发公司-微信商城小程序-上海咏熠 | 钛板_钛管_钛棒_钛盘管-无锡市盛钛科技有限公司 | 砍排机-锯骨机-冻肉切丁机-熟肉切片机-预制菜生产线一站式服务厂商 - 广州市祥九瑞盈机械设备有限公司 | 假肢-假肢价格-假肢厂家-河南假肢-郑州市力康假肢矫形器有限公司 | 嘉兴恒升声级计-湖南衡仪声级计-杭州爱华多功能声级计-上海邦沃仪器设备有限公司 | 微动开关厂家-东莞市德沃电子科技有限公司| 包装机传感器-搅拌站传感器-山东称重传感器厂家-济南泰钦电气 | 锻造液压机,粉末冶金,拉伸,坩埚成型液压机定制生产厂家-山东威力重工官方网站 | 步进_伺服_行星减速机,微型直流电机,大功率直流电机-淄博冠意传动机械 | 自动部分收集器,进口无油隔膜真空泵,SPME固相微萃取头-上海楚定分析仪器有限公司 | 探伤仪,漆膜厚度测试仪,轮胎花纹深度尺厂家-淄博创宇电子 | 雨水收集系统厂家-雨水收集利用-模块雨水收集池-徐州博智环保科技有限公司 | 硬度计_影像测量仪_维氏硬度计_佛山市精测计量仪器设备有限公司厂家 | 智能终端_RTU_dcm_北斗星空自动化科技 | 环讯传媒,永康网络公司,永康网站建设,永康小程序开发制作,永康网站制作,武义网页设计,金华地区网站SEO优化推广 - 永康市环讯电子商务有限公司 | 钢制拖链生产厂家-全封闭钢制拖链-能源钢铝拖链-工程塑料拖链-河北汉洋机械制造有限公司 | FAG轴承,苏州FAG轴承,德国FAG轴承-恩梯必传动设备(苏州)有限公司 | 数控走心机-走心机价格-双主轴走心机-宝宇百科| 玖容气动液压设备有限公司-气液增压缸_压力机_增压机_铆接机_增压器 | 上海盐水喷雾试验机_两厢式冷热冲击试验箱-巨怡环试 | 全球化工设备网—化工设备,化工机械,制药设备,环保设备的专业网络市场。 | 铝箔袋,铝箔袋厂家,东莞铝箔袋,防静电铝箔袋,防静电屏蔽袋,防静电真空袋,真空袋-东莞铭晋让您的产品与众不同 | 苏州西朗门业-欧盟CE|莱茵UL双认证的快速卷帘门品牌厂家 | 翻斗式矿车|固定式矿车|曲轨侧卸式矿车|梭式矿车|矿车配件-山东卓力矿车生产厂家 | EPK超声波测厚仪,德国EPK测厚仪维修-上海树信仪器仪表有限公司 | 雨燕360体育免费直播_雨燕360免费NBA直播_NBA篮球高清直播无插件-雨燕360体育直播 | RV减速机-蜗轮蜗杆减速机-洗车机减速机-减速机厂家-艾思捷 | 过滤器_自清洗过滤器_气体过滤器_苏州华凯过滤技术有限公司 | 成都中天自动化控制技术有限公司|