MySQL的Left、Right join(外连接)中的on条件与where条件区别

数据库通过JOIN连接两张或多张表返回记录时,都会生成一张中间的临时表,再将这张临时表返给用户。
对主表的筛选条件,应放在 where 条件后,如果在 on 之后,则对主表筛选来说,没有任何意义。

on、where 执行顺序

on的优先级,高于where
两者后面放置相同条件,可能会导致结果集不同,就是因为优先级所致。

假设有表,
table1:

id num
1 111
2 222

table2:

num name
111 first
222 second

执行如下两条查询:

1、select a.id,a.num,b.name from table1 a left join table2 b on (a.num = b.num and b.name='first');
2、select a.id,a.num,b.name from table1 a left join table2 b on (a.num = b.num) where b.name='first';

则,第1条SQL返回:

id num name
1 111 first
2 222 (Null)

第2条SQL返回:

id num name
1 111 first

第一条sql的执行流程:

首先找到b表的name为first的记录行on (a.num = b.num and b.name='first'),然后找到a的全部数据(left join),生成临时表返回数据。

第二个sql的执行流程:

先生成临时表(全量),然后执行where过滤b.name=’first’不为真的结果,最后返回数据。

因为on会首先过滤掉不符合条件的行,然后才会进行其它运算。
执行顺序: on > where > having, 因此理论上on是最快的。

多表查询时,on比where更早起作用。系统首先根据各个表之间的联接条件,把多个表整合成一个临时表,再由where进行过滤,之后再进行计算,计算完后再由having过滤。

对于JOIN参与的表的关联操作,如果需要不满足连接条件的行也被返回,就必需把连接条件放在ON后,不能放在WHERE后面,如果把连接条件放在了WHERE后面,那么所有的LEFT、RIGHT等操作将不起任何作用,对于这种情况,它的效果就完全等同于INNER连接。

结论

on是在生成临时表的时候使用的条件,不管on的条件是否起到作用,都会返回左表 (主表) 的行。
where则是在生成临时表之后使用的条件,此时已经不管是否使用了left join了,只要条件不为真的行,全部过滤。

Tips:

所有的join条件必需放在ON后面。
否则前面的LEFT、RIGHT关联将作为摆设,不起任何作用。

!!!

如果同时存在多个left join on,请注意on后面的条件与哪个表关联。
这一点很重要!!!
例如存在表A,B,C:
A left join B on A.x = B.x left join C on A.x = C.x;
B、C都与A建立了关联,但B和C之间是没有任何数据关联的。

但是,如果把A.x = C.x改成B.x = C.x,那么B和C的表数据会先建立关联并过滤数据,之后再与A表数据进行关联,可能会出现数据丢失。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,311评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,339评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,671评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,252评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,253评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,031评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,340评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,973评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,466评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,937评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,039评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,701评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,254评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,259评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,485评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,497评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,786评论 2 345

推荐阅读更多精彩内容