关于LEFT JOIN的一次理解

news2024/11/25 14:32:57

先看一段例子:

SELECT
	product_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 
FROM
	product_half_spu
	LEFT JOIN product_sku ON product_half_spu.id = product_sku.half_spu_id
	LEFT JOIN category_product ON product_half_spu.category_product_id = category_product.id 
WHERE
	product_half_spu.`status` = 1 
	AND product_sku.`status` = 1 
	AND category_product.`status` = 1 
	AND FIND_IN_SET( "1508", category_product.ancestor ) 
GROUP BY
	product_half_spu.id 
ORDER BY
	product_half_spu.create_on DESC

查询个数为40条

SELECT
	product_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 
FROM
	product_half_spu
	LEFT 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 ) 
WHERE
	product_half_spu.`status` = 1 
	AND FIND_IN_SET( "1508", category_product.ancestor ) 
GROUP BY
	product_half_spu.id 
ORDER BY
	product_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.coloradmin.cn/o/1090564.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

业务安全五重价值:防攻击、保稳定、助增收、促合规、提升满意度

目录 防范各类威胁攻击 保障业务的连续性和稳定性 保障业务的合规性 提升企业营收和发展 提升企业满意度和品牌知名度 2023年暑假被“票贩子”和“黄牛”攻陷。他们利用各种手段抢先预约名额,然后加价出售给游客,导致了门票供不应求的局面&#xff…

CNN-generated images are surprisingly easy to spot... for now

CNN-generated images are surprisingly easy to spot… for now----《目前CNN生成的图像非常容易被发现》 背景: 研究者们发现,仅仅对一种由CNN模型生成的图像进行训练的分类器,也可以检测许多其他模型生成的结果。由此提出这样的观点&#…

thinkphp5.1 获取缓存cache(‘cache_name‘)特别慢,php 7.0 unserialize 特别慢

thinkphp5.1 获取缓存cache(‘cache_name’)特别慢,php 7.0 unserialize 特别慢 场景: 项目中大量使用了缓存,本地运行非常快,二三百毫秒,部署到服务器后 一个表格请求就七八秒,最初猜想是数据库查询慢&am…

Java进阶 之 再论面向对象(2)——类的定义及对象的使用 封装Encapsulation 关键字private,this

前言 在上一篇博客中,我们从面向过程和面向对象的编程思想谈起,阐述了类和对象在Java中的编程中的应用,此外,对于对象的内存,变量作用域,参数传递等进行了阐述。 Java进阶 之 再论面向对象(1&…

噪声主动控制装置设计

目录 摘 要...................................................................................... 2 第一章 绪论........................................................................ 6 1.1 研究课题背景...................................................…

C++——多态调用和普通调用的本质区别

目录 一.多态特性 回顾一下多态特性的含义: 回顾多态特性的两大形成条件: 而普通调用和多态调用的本质区别在于: 二.理解调用 例一: 普通调用的理解1: 普通调用的理解2: 注:错误代码的…

【mfc/VS2022】计图实验:绘图工具设计知识笔记

绘制曲线(贝塞尔曲线): 转自:CDC 类 | Microsoft Learn 绘制一条或多条贝塞尔曲线。 BOOL PolyBezier(const POINT* lpPoints,int nCount);参数 lpPoints 指向包含曲线端点和控制点的 POINT 数据结构数组。 nCount 指定 lpPo…

移远通信C-V2X模组产品 助力车载生态建设跑出“加速度”

10月11日,移远通信受邀参加“长安创新驱动数智未来”行业研讨会。 本次会议围绕车载行业智能化转型取得的阶段性技术与终端成果展开讨论,旨在持续助力汽车行业智能出行的变革。移远通信产品总监侯海燕于会议上针对当下车载行业发展热点——C-V2X技术的相…

面经-北京泛微二面-Java开发

北京泛微二面-Java开发。以下内容为面试复盘,面试官问题无改动,回答已进行修正。 自我介绍 我是XXXX,来自XXX… 面试官提问: 1.像这些比赛的话,你是自己参加还是社团的人一起参加? 答:大多…

vue打包压缩

参考 https://www.cnblogs.com/lafitewu/p/8309305.html 注意:方法1和方法2不能同时用 取消打包的map config/index.js的productionSourceMap设置为false 抽取js 将部分常用又比较大的组件直接抽取为一个单独的js 打开webpack.base.conf.js,在module.exports.entry中添加想…

docker 搭建本地Chat GPT

要在CentOS7上安装Docker,您可以按照以下步骤进行操作: 1、更新系统包列表 sudo yum update2、安装Docker存储库的必要软件包 sudo yum install -y yum-utils device-mapper-persistent-data lvm23、添加Docker存储库 sudo yum-config-manager --add…

格式工厂怎么把两个视频合并在一起

免费的工具谁不喜欢呢,今天为大家介绍的是格式工厂这款多功能视频转换软件,然而今天主要为大家介绍的是格式工厂的视频合并功能。 是的,你没有听错,格式工厂除了转换之外,还可以视频合适、视频剪辑、视频分割、去水印…

Python3无法调用Sqlalchemy解决(mysqldb)

原因 在安装Sqlalchemy后运行程序报错 无法导入mysqldb,缺失模块 ImportError: No module named ‘MySQLdb’ 既然缺少 MySQLdb 这个模块,尝试按照正常的想法执行 pip install MySQLdbpip install mysql-python 应该能解决,但是却找不到…

MyBatis基础之自动映射、映射类型、文件注解双配置

文章目录 自动映射原理jdbcType同时启用配置文件和注解两种配置方式 自动映射原理 在 MyBatis 的配置文件(settings 元素部分)中,有一个 autoMappingBehavior 配置,其默认值为 PARTIAL ,表示 MyBatis 会自动映射&…

SpringCloud学习笔记-Nacos的命名空间的配置

目录 1.创建新的NameSpace2.给XXX-service配置NameSpace3.Nacos管理页面管理NameSpace4.Eureka和Nacos区别 Nacos提供了namespace来实现环境隔离功能。 nacos中可以有多个namespacenamespace下可以有group、service等不同namespace之间相互隔离,例如不同namespace的…

Spring6 - ioc

文章目录 IoC容器IoC容器在Spring的实现基于XML管理Bean获取bean**①方式一:根据id获取**②方式二:根据类型获取③方式三:根据id和类型④扩展知识 依赖注入之setter注入依赖注入之构造器注入特殊值处理为对象类型属性赋值为数组类型属性赋值为…

【Qt】字体更大的富文本

使用size属性只能生成7个等级的字号,超过7的都视作为7。 当需要更加夸张的字号时则需要使用style属性,除此之外利用该属性可以生成更加逆天丰富的样式,(style属性是CSS样式表。 稍微跑题一下:似乎有安全性的考量,不少…

监控系列(六)prometheus监控DMHS操作步骤

一、监控的操作逻辑 给操作系统安装expect命令expect脚本执行dmhs_console脚本执行 cpt / exec 命令用脚本进行过滤字符串过滤dm_export读取脚本与当前日期作比较,然后返回差值 二、安装步骤 1. linux中Expect工具的安装及使用方法 https://blog.csdn.net/wangta…

网络工程师知识点

1、OSI模型是每层的功能,用到的协议,使用到的设备,涉及到的数据传输单元 第七层应用层:提供应用程序间通信 (服务应用:http、ftp、dns) 第六层表示层:处理数据格式、数据加密等 第五层会话层&…

Redis 集群 Redis 事务 Redis 流水线 Redis 发布订阅 Redis Lua脚本操作

Redis 集群 & Redis 事务 & Redis 流水线 & Redis 发布订阅 Redis 集群linux安装redis主从配置查看当前实例主从信息 Redis Sentinelsentinel Redis Cluster Redis 事务Redis 流水线Redis 发布订阅Redis Lua脚本操作 Redis 集群 linux安装redis 下载安装包&#…