当前位置: 首页 > news >正文

关于LEFT JOIN的一次理解

先看一段例子:

SELECTproduct_half_spu.id AS 'halfSpuId',product_half_spu.half_spu_code,product_half_spu.half_spu_name,COUNT( product_sku.id ) AS 'skuCount',product_half_spu.create_on,product_half_spu.create_by,product_half_spu.upload_pic_date,product_half_spu.upload_pic_name,product_half_spu.pic_url,product_half_spu.pic_name,product_half_spu.category_product_id,category_product.ancestor 
FROMproduct_half_spuLEFT JOIN product_sku ON product_half_spu.id = product_sku.half_spu_idLEFT JOIN category_product ON product_half_spu.category_product_id = category_product.id 
WHEREproduct_half_spu.`status` = 1 AND product_sku.`status` = 1 AND category_product.`status` = 1 AND FIND_IN_SET( "1508", category_product.ancestor ) 
GROUP BYproduct_half_spu.id 
ORDER BYproduct_half_spu.create_on DESC

查询个数为40条

SELECTproduct_half_spu.id AS 'halfSpuId',product_half_spu.half_spu_code,product_half_spu.half_spu_name,COUNT( product_sku.id ) AS 'skuCount',product_half_spu.create_on,product_half_spu.create_by,product_half_spu.upload_pic_date,product_half_spu.upload_pic_name,product_half_spu.pic_url,product_half_spu.pic_name,product_half_spu.category_product_id,category_product.ancestor 
FROMproduct_half_spuLEFT JOIN product_sku ON ( product_half_spu.id = product_sku.half_spu_id AND product_sku.`status` = 1 )LEFT JOIN category_product ON ( product_half_spu.category_product_id = category_product.id AND category_product.`status` = 1 ) 
WHEREproduct_half_spu.`status` = 1 AND FIND_IN_SET( "1508", category_product.ancestor ) 
GROUP BYproduct_half_spu.id 
ORDER BYproduct_half_spu.create_on DESC

查询结果为44条。

可以看到这两条sql的区别就在于product_sku.`status` = 1和 category_product.`status` = 1的摆放位置。如果这两个条件,出现在where之前,就表示是对匹配到的数据做过滤。如果是放在where 之后,就表示对整个数据做过滤,不管是否有匹配到。举个例子:

idvaluestatus
1A-1
2B1
3C1
4D-1
idvaluemaster_value
11A
22A
33A
44B
55B
66B
77C
88C
99C

主表一有4条数据A、B、C和D,对象的子表二有如下对应关系:A -》1、2、3,B-》4、5、6,

c-》7、8、9,D没有对应的子表数据。并且A的status为-1,B的status的为1,C的status为1,D的status为-1。如果用刚才的sql去理解,如果条件放在了where之前,那么就是将匹配到了的数据进行过滤。这边匹配到的数据有A、B、和C,然后过滤status为-1之后,只剩下B和C,因为D没有匹配到数据,所以不参与过滤,所以最终剩下的结果就是A、B、D。而条件如果放到了where之后,那么过滤的逻辑就是直接过滤主表的数据,此时,A和D都会过滤,只剩下了B和C。

http://www.lryc.cn/news/192062.html

相关文章:

  • 各报文段格式集合
  • 【算法-动态规划】最长公共子序列
  • 区块链游戏的开发流程
  • 目标检测网络系列——YOLO V2
  • 15. Java反射和注解
  • pdf处理工具 Enfocus PitStop Pro 2022 中文 for mac
  • 微信小程序入门开发教程
  • php函数
  • 3.3 封装性
  • Redis魔法:点燃分布式锁的奇妙实现
  • iOS 项目避坑:多个分类中方法重复实现检测
  • 【003】EIS数据分析_#LIB
  • Sprint framework Day07:注解结合 xml 配置
  • LiveGBS流媒体平台GB/T28181功能-国标流媒体服务同时兼容内网收流外网收流多网段设备收流
  • js题解(四)
  • 如何进行大数运算和高精度计算?
  • 身份证读卡器跟OCR有何区别?哪个好?
  • 华为云云耀云服务器L实例评测 | 实例评测使用之硬件参数评测:华为云云耀云服务器下的 Linux 网络监控神器 bmon
  • C++ 设计模式 —— 组合模式
  • 华为云Stack的学习(九)
  • Flink中jobmanager、taskmanager、slot、task、subtask、Parallelism的概念
  • OpenHarmony docker环境搭建
  • 【计算机网络】网络编程接口 Socket API 解读(11)
  • Qt工具开发,该不该跳槽?
  • 【深度学习】DDPM,Diffusion,概率扩散去噪生成模型,原理解读
  • HT8699:内置 BOOST 升Y双声道音频功率放大器
  • 利达卓越:关注环保事业,持续赋能科技
  • Spring MVC中通过配置文件配置定时任务
  • AI项目十六:YOLOP 训练+测试+模型评估
  • Flink报错could not be loaded due to a linkage failure