LEFT JOIN关联查询中ON条件和WHERE条件浅析

首先,需要注意的是,使用LEFT JOIN进行连接查询时,不论ON条件是否为真,都会返回左表的所有记录

 

  1.  ON条件是生成临时表时使用的条件(仅在关联右表查询时对右表筛选起作用,无论条件是否为真都会返回左表所有记录)
  2. WHERE条件是生成临时表后使用的条件(对生成的临时表再次进行条件过滤,此时条件筛选对全表有效,条件不为真就会过滤掉)

假设我们有class表和achieve表,分别是班级表和成绩表

class表(班级表)

班级(class)成员(student)
一班张三
二班李四
三班王五

achieve表(成绩表)

成员(student)课程(courses)成绩(result)
张三语文70
李四数学85
李四英语90

 

  • 仅on条件关联查询
select * from class a left join achieve b on a.student = b.student;
a.classa.studentb.studentb.coursesb.result
一班张三张三语文70
二班李四李四数学85
二班李四李四英语90
三班王五   
  • on条件关联查询 + on条件筛选(右表筛选条件) 
select * from class a left join achieve b on a.student = b.student and b.result = 70;
a.classa.studentb.studentb.coursesb.result
一班张三张三语文70
二班李四   
三班王五   

注:根据left join on条件的关联查询规则,会取左表所有记录,再与右表关联记录时,会限制右表b.result = 70,故右表仅有一条记录符合条件;

  • on条件关联查询 + on条件筛选(左表筛选条件)
select * from class a left join achieve b on a.student = b.student and a.student = '李四';

 

a.classa.studentb.studentb.coursesb.result
一班张三   
二班李四李四数学85
二班李四李四英语90
三班王五   

注:根据left join on条件的关联查询规则,会取左表所有记录,再与右表关联记录时,会限制左表a.student = '李四'去关联右表,故右表仅有b.student = ‘李四’ 的两条记录符合条件;

  • on条件关联查询 + where条件筛选
select * from class a left join achieve b on a.student = b.student where b.result = 70;
a.classa.studentb.studentb.coursesb.result
一班张三张三语文70

注:根据left join on条件的关联查询规则,会取左表所有记录,再与右表关联记录;然后where条件会对关联后的全表进行筛选,此时再筛选b.student = 70 ,仅有一条全表记录符合条件;

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在MySQLLEFT JOIN是一种连接查询的方式,可以链接两个或多个表格。当使用LEFT JOIN时,将左边的表格的所有记录与右边表格的匹配记录连接起来,而不管右边表格的记录是否存在。 在LEFT JOIN,将条件放在ON和WHERE子句的区别如下: 1. ON子句:这是在连接两个表格时使用的条件。在ON子句,我们可以指定要使用的列进行连接,例如:ON table1.column = table2.column。通过在ON子句指定连接条件,可以确保将两个表格匹配的记录连接起来。如果在ON子句省略连接条件,则会返回左边表格的所有记录与右边表格的每条记录的组合。 2. WHERE子句:该子句用于在连接两个表格之后对结果进行筛选。在WHERE子句,我们可以使用条件对连接后的结果进行筛选,例如:WHERE column1 = value。通过在WHERE子句指定过滤条件,可以从连接后的结果选择满足条件的记录。如果在WHERE子句省略条件,则返回连接后的所有记录。 因此,ON子句用于连接两个表格,而WHERE子句用于筛选连接后的结果。放置条件的不同位置会对查询结果产生不同的影响。当连接条件放在ON子句时,会在连接时对两个表格进行匹配。而当条件放在WHERE子句时,会在连接后对匹配的结果进行过滤。 总结:ON子句用于连接表格,WHERE子句用于筛选连接后的结果。根据具体需求,我们可以选择将条件放置在ON子句或WHERE子句来实现不同的查询目的。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值