• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    详解mysql 使用left join添加where条件的问题分析

    当前需求:

    有group和factor两张表,一个group对应多个factor,现在想查询有效的group和对应的有效的factor,两个表都有isDel逻辑删除标志。

    最开始的错误写法一

    SELECT g.*,f.* FROM groups g LEFT JOIN factor f ON f.groupId = g.id where g.isDel=0 and f.isDel=0

    LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行。
    上边这样写左边表要是在右边表没有对应数据是查询不出来的,原因就是f.isDel=0这个代码问题。

    错误写法二:

    SELECT g.*,f.* FROM groups g LEFT JOIN factor f ON f.groupId = g.id and g.isDel=0 and f.isDel=0

    这种写法g.isDel=0是不会生效的,导致查询数据根本不对。

    原因分析:

    left join中关于where和on条件的几个知识点:

    正确的写法:

    SELECT g.*,f.* FROM groups g LEFT JOIN factor f ON f.groupId = g.id and f.isDel=0 where g.isDel=0

    结论:

    1.对左表添加条件限制需在where条件中添加,不能放到on后面
    2.对右表添加条件限制需放到on后面,在where条件中添加会有数据行数差异出现问题。

    到此这篇关于详解mysql 使用left join添加where条件的问题分析的文章就介绍到这了,更多相关mysql left join添加where内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    您可能感兴趣的文章:
    • mysql中left join设置条件在on与where时的用法区别分析
    • MySQL left join操作中on和where放置条件的区别介绍
    • 解析mysql left( right ) join使用on与where筛选的差异
    上一篇:浅谈为什么Mysql数据库尽量避免NULL
    下一篇:MySQL查询优化之查询慢原因和解决技巧
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    详解mysql 使用left join添加where条件的问题分析 详解,mysql,使用,left,join,