mysql left where_mysql中left join设置条件在on与where时的用法区别解析

本篇文章小编给大家分享一下mysql中left join设置条件在on与where时的用法区别解析,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。

一、首先我们准备两张表来进行测试。

CREATE TABLE `a` (

`id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID',

`name` varchar(32) DEFAULT '' COMMENT '名称',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

CREATE TABLE `b` (

`id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID',

`a_id` int(11) DEFAULT '0' COMMENT 'a表ID',

`name` varchar(32) DEFAULT '' COMMENT '名称',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

两个表的数据如图所示:

f89fc114286ed1d9f51a5216734d296e.png

运行下面左连接查询:

select * from a left join b on a.id = b.a_id;

bc1e71d30b79e6b46bb40ebd08c729c1.png

我们分别在on和where后面加上条件,看看执行结果是否相同。

select * from a left join b on a.id = b.a_id and b.id > 3;

346672e38c602d9dda32e345f3bde296.png

select * from a left join b on a.id = b.a_id where b.id > 3;

7e2976e946cb29af6b03924472be6043.png

上面的两条语句,条件我们设置的是一样的都是b.id > 3,为什么显示结果不同。

sql语句查询的关键字顺序一般为 from > where > group by > having > order by

left join 在 from范围,on 条件会先对 left join 的右表进行筛选,筛选完后的结果 where 再进行筛选。

多个 left join 会生成一张临时表,on 条件是对 left join 右表进行条件过滤,where 条件针对最后生成的临时表进行过滤。

所以:

b.id > 3 的条件如果写在 on 后面,则是先对右边表(关联表)进行筛选,得出符合条件的行,然后主表 left join ,返回主表所有的行,右边表没匹配上的用 null 表示。

b.id > 3 的条件如果写在 where 后面,则是先主表 left join 右边表(关联表),返回所有的行,然后 where 条件再对结果进行筛选。

注意:on 后面的条件是针对右边的表(关联表),对主表没什么作用。

select * from a left join b on a.id = b.a_id and a.id > 3;

a55e6e73b08cd466f7ad80fc96540a7a.png

我们在on 后面添加了对主表的条件 a.id > 3,不过主表的数据仍然全部显示出来了,但是影响了右边表(关联表)的显示。

如果想要对主表进行筛选,应该把条件写在where后。

select * from a left join b on a.id = b.a_id where a.id > 3;

0ffd54d64313063cbc09d770ff3da5ab.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值