左连接的左边为什么不全显示

left join后面加上where条件浅析

select a.*,b.*
from table1 a
left join table2 b on b.X=a.X
where XXX

如上:一旦使用了left join,没有where条件时,左表table1会显示全部内容

    使用了where,只有满足where条件的记录才会显示(左表显示部分或者全部不显示)

so。。。。

left join的困惑:一旦加上where条件,则显示的结果等于inner join 

原因分析:

数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户;

where条件是在临时表生成好后,再对临时表进行过滤的条件;

因此:where 条件加上,已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。 

解决方案:

1、where过滤结果作为子查询,和主表left,如下:

复制代码

select a.*,tmp.*
from table1 a
left join(
    select a.*,b.*
    from table1 a
    left join table2 b on b.X=a.X
    where XXX
)tmp

复制代码

很明显,子查询语句无论 left join、inner join都没啥区别了

2、查询条件放在on后面

1

2

3

select a.*,b.*

from table1 a

left join table2 b on b.X=a.X and XXX

注意:where XXX去掉,改为链接条件on后面的 and XXX

分析:

 on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。

结论 a表和b表 做关联 

1. on a.id=b.id and a.name='张三' 这种在on后边直接and 的对a表无效  只要不加where 左边永远都是全显示    

2.on a.id=b.id where a.name='张三' 这种则查出只有是张三的数据

  • 4
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
在MySQL中,左连接(left join)是一种连接方式,它会将左表的记录全部显示出来,并且只显示符合搜索条件的右表记录。如果右表的记录不足,那么显示的地方会填充为NULL。而右连接(right join)则与左连接相反,它会将右表的记录全部显示出来,并且只显示符合搜索条件的左表记录。如果左表的记录不足,那么显示的地方会填充为NULL。两者的区别在于显示的表不同。 如果你在使用MySQL的左连接时,发现右表的字段无法显示,可能有以下几个原因: 1. 检查连接的条件是否正确:在左连接中,连接的条件应该是左表的某个字段与右表的某个字段相等。请确认连接条件是否正确,以确保左连接能够正确地连接两个表。 2. 检查过滤条件的位置:在左连接中,过滤条件应该放在连接条件之后的where子句中,以确保过滤条件只对右表生效。如果将过滤条件放在连接条件之前的on子句中,可能会导致左表的数据也被过滤掉,从而导致右表字段无法显示。 3. 检查字段的别名:有时候,在使用左连接时,如果两个表存在相同的字段名,那么在查询结果中只会显示一个字段。这时可以给字段设置别名,以区分它们。请检查字段的别名是否正确设置。 总结来说,如果在MySQL的左连接中,右表的字段无法显示,首先需要检查连接的条件是否正确,其次要确认过滤条件的位置是否正确,最后需要检查字段的别名是否设置正确。这样可以确保左连接能够正常显示右表的字段。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值