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

left join详解

left join详解LEFT JOIN 详解一、基本语法二、执行逻辑与结果特点三、示例说明四、与其他 JOIN 的对比五、ON 条件与 WHERE 条件的区别重要六、多表 LEFT JOIN七、性能考虑八、常见应用场景九、与其他数据库的差异十、小结1.不考虑where条件下,left join 会把左表所有数据查询出来on及其后面的条件仅仅会影响右表的数据(符合就显示,不符合全部为null)2.在匹配阶段where子句的条件都不会被使用仅在匹配阶段完成以后where子句条件才会被使用它将从匹配阶段产生的数据中检索过滤3.所以左连接关注的是左边的主表数据不应该把on后面的从表中的条件加到where后这样会影响原有主表中的数据4.where后面是先连接然生成临时查询结果然后再筛选on后面先根据条件过滤筛选再连接生成临时查询结果5.对于条件在on加个and还是用子查询查询结果是一模一样的至于如何使用这个需要分情况用子查询的话会多一个maptask但是如果利用这个子查询能过滤到很多数据的话用子查询还是比较建议的因为不会加载太多的数据到内存中如果过滤数据不多的情况下建议用on后面加and条件LEFT JOIN详解LEFT JOIN也称为LEFT OUTER JOIN是 SQL 中最常用的连接类型之一。它返回左表中的所有行以及右表中与左表匹配的行如果右表中没有匹配则结果中右表部分返回NULL。一、基本语法SELECT列名列表FROM左表表名LEFTJOIN右表表名ON连接条件;左表FROM子句中指定的表结果集中会保留它的全部行。右表LEFT JOIN后面指定的表只有满足连接条件的行才会被包含。ON 条件指定左表和右表如何关联如左表.id 右表.id。可选关键字OUTER可省略LEFT OUTER JOIN等价于LEFT JOIN。二、执行逻辑与结果特点第一步取左表的所有行。第二步对左表的每一行在右表中查找满足ON条件的行。如果找到一条或多条匹配行则与左表行组合输出一行或多行匹配多少条输出多少条。如果一条都没找到则结果中右表的所有字段填充NULL但仍输出该左表行。第三步如果左表有重复行结果中也会保留重复不去重。核心特点左表行数永远是被完整保留的右表只贡献匹配的行或NULL。三、示例说明假设有以下两张表学生表studentsstudent_idname1张三2李四3王五成绩表scoresstudent_idsubjectscore1数学901英语852数学78查询每个学生及其成绩即使没有成绩也要显示SELECTs.student_id,s.name,sc.subject,sc.scoreFROMstudents sLEFTJOINscores scONs.student_idsc.student_id;结果student_idnamesubjectscore1张三数学901张三英语852李四数学783王五NULLNULL学生 3王五没有成绩右表字段为NULL但左表行仍被保留。学生 1 有两条成绩所以输出两行。四、与其他 JOIN 的对比JOIN 类型返回结果INNER JOIN只返回两个表中都匹配的行LEFT JOIN返回左表全部行右表无匹配时补NULLRIGHT JOIN返回右表全部行左表无匹配时补NULL可被LEFT JOIN通过调换表顺序替代FULL OUTER JOIN返回两表全部行对方无匹配时补NULLMySQL 不直接支持CROSS JOIN笛卡尔积不指定条件五、ON 条件与 WHERE 条件的区别重要ON 条件决定如何连接两个表在连接过程中应用。对于LEFT JOINON 中的右表条件不会过滤掉左表行只会影响右表是否匹配。WHERE 条件在连接完成之后对最终结果集进行过滤。如果 WHERE 条件中包含右表的列并且要求该列非空实际上会将左连接转换为内连接因为 NULL 会被过滤掉。错误示例想找没有成绩的学生但误用了 WHERESELECTs.student_id,s.nameFROMstudents sLEFTJOINscores scONs.student_idsc.student_idWHEREsc.scoreISNULL;-- 正确只保留无成绩的学生危险示例想找成绩大于 80 的学生但误写为SELECTs.student_id,s.name,sc.scoreFROMstudents sLEFTJOINscores scONs.student_idsc.student_idWHEREsc.score80;这样会丢失成绩为 NULL 的学生即无成绩的学生而且学生 2 成绩 78 也会被过滤。结果与INNER JOIN相同但可能不符合预期。六、多表LEFT JOIN可以连续使用多个LEFT JOINSELECT*FROMtable1LEFTJOINtable2ONt1.keyt2.keyLEFTJOINtable3ONt1.keyt3.key;每个LEFT JOIN都以其左侧的当前结果集为左表依次连接。注意当连接多个表时ON条件中的列可能来自前面任何已经连接的表。七、性能考虑LEFT JOIN通常比INNER JOIN稍慢因为它必须保留左表所有行即使右表没有匹配。在右表的连接列上创建索引可以显著提升性能。尽量避免在大表上使用LEFT JOIN后再用WHERE过滤右表的非空列这种情况下通常INNER JOIN更合适。八、常见应用场景主表可选明细如查询所有员工及其所属部门即使有些员工未分配部门。查找缺失关联通过WHERE 右表主键 IS NULL找出左表中在右表没有对应记录的行。SELECTs.*FROMstudents sLEFTJOINscores scONs.student_idsc.student_idWHEREsc.student_idISNULL;-- 找出没有成绩的学生生成报表保留所有分类如月份、产品类别即使某些分类没有数据。避免因右表无匹配而丢失左表行。九、与其他数据库的差异MySQL、PostgreSQL、SQL Server、Oracle语法和语义完全一致。Hive/Spark SQL支持LEFT JOIN但需要注意 NULL 处理及 ON 条件中不允许出现复杂表达式某些版本有限制。SQLite完全支持。十、小结要点说明保留左表全部行即使右表没有匹配左表行也会出现右表无匹配时为 NULL右表所有列填充 NULLON vs WHEREON 决定连接WHERE 过滤最终结果WHERE 右表列条件可能“破坏”左连接语义性能索引右表连接列避免不必要的左连接常见用途查找缺失关联、保留主表全部信息掌握LEFT JOIN是 SQL 进阶的关键一步它让你能够安全地保留基准表的所有记录同时根据需要关联补充信息。

相关文章:

left join详解

left join详解LEFT JOIN 详解一、基本语法二、执行逻辑与结果特点三、示例说明四、与其他 JOIN 的对比五、ON 条件与 WHERE 条件的区别(重要!)六、多表 LEFT JOIN七、性能考虑八、常见应用场景九、与其他数据库的差异十、小结1.不考虑where条…...

把openEuler当微服务跑:Docker Compose编排实战,管理Nginx+MySQL多容器集群

基于openEuler的微服务集群实战:Docker Compose编排NginxMySQL全流程 在云原生技术席卷企业IT基础设施的今天,将操作系统容器化已成为提升资源利用率、加速应用交付的标准实践。openEuler作为面向数字基础设施的开源操作系统,凭借其卓越的多架…...

微信支付运营户 vs 基本户彻底搞懂:商家转账到零钱的资金流与账户权限实操指南

微信支付商户账户体系全解析:从资金流到权限设置的实战指南 第一次登录微信支付商户后台时,那些专业术语和复杂的资金流向是否让你感到手足无措?作为刚接手这项工作的财务或技术人员,理解运营户和基本户的区别就像学习一门新语言…...

手把手教你用XML为RimWorld Mod添加第一个新物品:从Defs文件到游戏内生效全流程

从零开始为RimWorld Mod添加自定义武器:XML实战指南 第一次打开RimWorld的Mod文件夹时,那些密密麻麻的XML文件可能让人望而生畏。但别担心——每个资深Mod作者都经历过这个阶段。今天我们就用最直观的方式,带你完成第一个可运行的物品Mod&…...

别再死记M法T法公式了!用Arduino和常见编码器手把手教你电机测速(附代码)

用Arduino实战编码器测速:告别公式背诵,从接线到可视化分析 当你第一次拿到那个小巧的增量式编码器时,可能会被那些专业术语吓到——M法、T法、分辨率、倍频...但我要告诉你一个秘密:这些概念远没有看起来那么可怕。本文将带你用最…...

MRIcron的dcm2niix命令行参数详解:从-f到-z,每个选项在医学影像转换中到底有什么用?

MRIcron的dcm2niix命令行参数深度解析:精准控制医学影像转换的20个关键技巧 在神经影像研究领域,DICOM到NIfTI的格式转换是数据处理流程中的关键第一步。作为业内广泛使用的转换工具,MRIcron套件中的dcm2niix以其高效稳定的表现赢得了研究人员…...

如何在极域电子教室控制下找回学习自主权

如何在极域电子教室控制下找回学习自主权 【免费下载链接】JiYuTrainer 极域电子教室防控制软件, StudenMain.exe 破解 项目地址: https://gitcode.com/gh_mirrors/ji/JiYuTrainer 你是否经历过这样的场景?老师在全班电脑上开启了极域电子教室的屏幕广播&…...

茶叶病害目标检测数据集 茶叶病害识别管理系统 数据集+界面+模型 识别功能包括登录、导入模型、图片、视频、实时检测

01 — 茶叶病害目标检测(数据集/界面 基于YOLO全系列,界面非常美观,非常详细)模块/类别 详细说明 一、技术栈编程语言:PythonGUI框架:PyQt5(界面美观、操作友好)目标检测模型框架&am…...

艾尔登法环终极优化指南:解锁帧率与游戏增强的完整教程

艾尔登法环终极优化指南:解锁帧率与游戏增强的完整教程 【免费下载链接】EldenRingFpsUnlockAndMore A small utility to remove frame rate limit, change FOV, add widescreen support and more for Elden Ring 项目地址: https://gitcode.com/gh_mirrors/el/El…...

PDF-Extract-Kit-1.0与STM32CubeMX的嵌入式集成方案

PDF-Extract-Kit-1.0与STM32CubeMX的嵌入式集成方案 1. 工业现场的真实需求场景 在工厂自动化产线里,设备运行日志、维修手册、质检报告这些资料大多以PDF格式存在。操作员需要快速从几十页的技术文档中提取某个传感器的参数范围,或者从维修记录里找出…...

Qwen2.5-VL-7B-Instruct部署教程:离线环境无网络安装依赖包完整方案

Qwen2.5-VL-7B-Instruct部署教程:离线环境无网络安装依赖包完整方案 1. 学习目标与前置准备 Qwen2.5-VL-7B-Instruct是一款强大的多模态视觉-语言模型,能够同时处理图像和文本输入,生成高质量的响应。本教程将带你完成在离线环境下的完整部…...

本地Cookie导出工具:解决Web开发中的认证数据管理难题

本地Cookie导出工具:解决Web开发中的认证数据管理难题 【免费下载链接】Get-cookies.txt-LOCALLY Get cookies.txt, NEVER send information outside. 项目地址: https://gitcode.com/gh_mirrors/ge/Get-cookies.txt-LOCALLY 在Web开发和数据采集领域&#x…...

玄机靶场实战:从应急响应到vulntarget-j-02的攻防解析

1. 玄机靶场与应急响应实战入门 第一次接触玄机靶场时,我被它高度仿真的企业内网环境震撼到了。这个基于Docker构建的靶场平台完美复现了企业常见的Windows服务器、Web应用和数据库服务,甚至连日志记录和行为特征都和真实环境一模一样。对于想学习网络安…...

1篇2章10节:介绍 CO-STAR 提示词工程框架

CO-STAR 框架的核心理念是将系统化目标管理的思路应用于提示词设计。框架由六大要素组成,通过系统化拆解,CO-STAR 帮助用户将复杂或多维任务转化为结构化、可控的提示词,提升 AI 理解和执行的准确性。CO-STAR 提示词工程框架在现代社会&#…...

终极指南:如何在OBS中一键实现AI背景移除与低光增强

终极指南:如何在OBS中一键实现AI背景移除与低光增强 【免费下载链接】obs-backgroundremoval An OBS plugin for removing background in portrait images (video), making it easy to replace the background when recording or streaming. 项目地址: https://gi…...

Graphormer部署案例:科研云平台中Graphormer作为标准化AI分子服务模块

Graphormer部署案例:科研云平台中Graphormer作为标准化AI分子服务模块 1. 项目概述 Graphormer是一种基于纯Transformer架构的图神经网络模型,专门为分子图(原子-键结构)的全局结构建模与属性预测而设计。该模型在OGB、PCQM4M等…...

文墨共鸣效果展示:当传统水墨美学遇上现代AI技术

文墨共鸣效果展示:当传统水墨美学遇上现代AI技术 1. 视觉与技术的完美融合 1.1 水墨美学的数字重生 在数字化浪潮中,"文墨共鸣"项目创造性地将中国传统水墨美学与现代AI技术相结合。这个独特的语义相似度分析工具摒弃了传统技术工具的冰冷界…...

Happy Island Designer终极指南:从零开始打造梦想岛屿的完整教程

Happy Island Designer终极指南:从零开始打造梦想岛屿的完整教程 【免费下载链接】HappyIslandDesigner "Happy Island Designer (Alpha)",是一个在线工具,它允许用户设计和定制自己的岛屿。这个工具是受游戏《动物森友会》(Animal…...

终极指南:为什么Tree of Thoughts思维树算法能提升AI推理能力70%?

终极指南:为什么Tree of Thoughts思维树算法能提升AI推理能力70%? 【免费下载链接】tree-of-thoughts Plug in and Play Implementation of Tree of Thoughts: Deliberate Problem Solving with Large Language Models that Elevates Model Reasoning by…...

Jetson设备文件系统损坏?别急着重刷!试试这个fsck.ext4急救指南

Jetson设备文件系统损坏?别急着重刷!试试这个fsck.ext4急救指南 当你的Jetson设备突然无法启动,屏幕上跳出EXT4-fs error loading journal或cant read superblock这类错误时,大多数人的第一反应可能是翻出刷机工具包,准…...

精通Venera漫画源:从零构建个性化漫画生态系统的完整指南

精通Venera漫画源:从零构建个性化漫画生态系统的完整指南 【免费下载链接】venera A comic app 项目地址: https://gitcode.com/gh_mirrors/ve/venera 你是否曾想过将分散在不同平台的漫画资源整合到一个统一的阅读环境中?Venera作为一款开源漫画…...

如何快速掌握Google Cloud服务的Go实现:golang-samples完整指南

如何快速掌握Google Cloud服务的Go实现:golang-samples完整指南 【免费下载链接】golang-samples Sample apps and code written for Google Cloud in the Go programming language. 项目地址: https://gitcode.com/gh_mirrors/go/golang-samples GitHub 加速…...

如何快速解决Windows热键冲突问题:Hotkey Detective完整使用指南

如何快速解决Windows热键冲突问题:Hotkey Detective完整使用指南 【免费下载链接】hotkey-detective A small program for investigating stolen key combinations under Windows 7 and later. 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective …...

CC工具箱实战:SHP转TXT通用版,从数据到自定义描述的完整流程

1. 为什么需要SHP转TXT工具? 在日常的GIS数据处理工作中,我们经常会遇到需要将SHP格式的地块数据转换为特定格式的TXT文件的需求。比如在土地调查项目中,上级部门可能要求提交包含地块坐标和属性的文本文件;在数据上报时&#xff…...

Solana验证节点同步太慢?保姆级快照下载与加速同步配置指南

Solana验证节点同步太慢?保姆级快照下载与加速同步配置指南 运行Solana验证节点时,最令人头疼的莫过于漫长的区块同步过程。我曾亲眼见过一个节点花了整整三天才完成同步,期间消耗的服务器资源和运维精力让人抓狂。不过别担心,通…...

Qwen3.5-4B-Claude-Opus开源大模型教程:Web镜像安全配置最佳实践

Qwen3.5-4B-Claude-Opus开源大模型教程:Web镜像安全配置最佳实践 1. 模型与镜像概述 Qwen3.5-4B-Claude-4.6-Opus-Reasoning-Distilled-GGUF是基于Qwen3.5-4B的推理蒸馏模型,特别强化了结构化分析、分步骤回答以及代码与逻辑类问题的处理能力。该版本以…...

从地图文件到实际导航:手把手教你用Cartographer的PGM/YAML配置Amcl定位

从地图文件到实际导航:手把手教你用Cartographer的PGM/YAML配置Amcl定位 在机器人自主导航的实践中,Cartographer作为SLAM领域的标杆工具,其生成的地图文件(.pgm和.yaml)常常成为下游导航模块的起点。但许多开发者发现…...

运动控制系统(五)-闭环的PI控制系统

上一节我们讲到控制系统的三大规律,第一条就是“比例控制系统无法消除“静差”。这一节我们解决这个问题。闭环积分控制在介绍静差的时候我们提到了:静差的存在主要是因为比例控制器仅依赖于当前误差ΔUn来进行调节,而没有考虑过去&#xff0…...

Pixel Dream Workshop 大模型一键部署教程:3步搭建创意生成环境

Pixel Dream Workshop 大模型一键部署教程:3步搭建创意生成环境 1. 开篇:为什么选择Pixel Dream Workshop? 如果你正在寻找一个能快速生成高质量创意内容的工具,Pixel Dream Workshop绝对值得一试。这个基于大模型的开源项目&am…...

SleeperX:Mac智能睡眠控制终极方案,告别合盖中断烦恼

SleeperX:Mac智能睡眠控制终极方案,告别合盖中断烦恼 【免费下载链接】SleeperX MacBook prevent idle/lid sleep! Hackintosh sleep on low battery capacity. 项目地址: https://gitcode.com/gh_mirrors/sl/SleeperX 在Mac使用中,你…...