mysql left join行数的变化

  1. 与左表行数相同,原因:

    • 右表中的连接字段没有重复的现象
    • 最后不用where语句进行筛选
  2. 行数变多,原因:

    • 右表中的连接字段有重复的现象
  3. 行数变少,原因:

    • 一定是在最后加入了where语句
    • 否则一定不会出现left join后,行数变少的情况
left join时,放在 on 后面的条件与放在 where 后面的条件有什么不同:

on是在生成连接表时起作用,where是生成连接表之后对连接表再进行过滤:
当使用left join时,无论on的条件是否满足,都会返回左表的所有记录,
对于满足的条件的记录,两个表对应的记录会连接起来,
对于不满足条件的记录,那右表字段全部是null;
当使用right join时,类似,只不过是全部返回右表的所有记录

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容