mysql连表查询on条件_mysql 外连接的时候,条件在on后面和条件在where后面的区别...

最近使用mysql的时候碰到一个问题:当一个表外联另一个表的时候,将一些查询条件放在on后面和放在where后面不太一样:

学生分数表stuscore:

b114fa3ecc498315bfc033821e145e1a.png

当查询语句如下(查询语句1):

SELECT a.name,a.subject,a.score,a.stuid ,b.name,b.subject,b.score,b.stuid

FROM stuscore a

LEFT JOIN stuscore b ON a.subject=b.subject WHERE a.score >100

查询结果如下:查询结果为空;

当查询语句如下时(查询语句2):

SELECT a.name,a.subject,a.score,a.stuid ,b.name,b.subject,b.score,b.stuid

FROM stuscore a

LEFT JOIN stuscore b ON a.subject=b.subject AND a.score >100

查询的结果如下:

d90778433c81c8e1129ff6fa116465e5.png

我发现查询结果不为空,但是后面的字段都为空。

总结原因:当条件放在on后面的时候(如查询语句2),后面的条件作为连接条件,如果不满足,则显示左的一条数据,由标的查询字段都用null填充;

当条件放在where后面的时候(如查询语句1),后面的条件作为查询条件,是在连表以后,再过滤的条件,只要不满足就过滤掉,所以查询出来的结果为空。

所以一定要知道外连接的查询原理。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值