一、首先我们准备两张表来进行测试。
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',PRIMARY KEY (`ID`)) ENGINE=InnoDB DEFAulT CHARSET=utf8;
两个表的数据如图所示:
运行下面左连接查询:
select * from a left join b on a.ID = b.a_ID;
我们分别在on和where后面加上条件,看看执行结果是否相同。
select * from a left join b on a.ID = b.a_ID and b.ID > 3;
select * from a left join b on a.ID = b.a_ID where b.ID > 3;
上面的两条语句,条件我们设置的是一样的都是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;
我们在on 后面添加了对主表的条件 a.ID > 3,不过主表的数据仍然全部显示出来了,但是影响了右边表(关联表)的显示。
如果想要对主表进行筛选,应该把条件写在where后。
select * from a left join b on a.ID = b.a_ID where a.ID > 3;总结
以上是内存溢出为你收集整理的mysql中left join设置条件在on与where时的区别全部内容,希望文章能够帮你解决mysql中left join设置条件在on与where时的区别所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)