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

七、JOIN 语法详解与实战示例

一、JOIN 的作用与分类

JOIN 操作用于合并两个或多个表的行,基于表之间的关联字段。以下是常见的 JOIN 类型:

JOIN 类型描述
INNER JOIN返回两个表匹配的记录
LEFT JOIN返回左表所有记录 + 右表匹配记录(右表无匹配则为NULL)
RIGHT JOIN返回右表所有记录 + 左表匹配记录(左表无匹配则为NULL)
FULL JOIN返回所有记录(MySQL不支持,可用UNION模拟)
CROSS JOIN返回笛卡尔积(所有可能的组合)

二、INNER JOIN(内连接)

语法与作用

SELECT 字段
FROM 表A
INNER JOIN 表B ON 表A.字段 = 表B.字段;
  • 作用:仅返回两表中匹配的行
  • 使用场景:需要精确关联数据的场景(如订单与用户信息关联)

示例

表结构

-- 用户表
CREATE TABLE users (user_id INT PRIMARY KEY,name VARCHAR(50)
);
INSERT INTO users VALUES (1, '张三'), (2, '李四');-- 订单表
CREATE TABLE orders (order_id INT PRIMARY KEY,user_id INT,amount DECIMAL(10,2)
);
INSERT INTO orders VALUES (1001, 1, 299.00), (1002, 3, 599.00);

查询:获取有订单的用户信息

SELECT u.name, o.order_id, o.amount
FROM users u
INNER JOIN orders o ON u.user_id = o.user_id;

结果

nameorder_idamount
张三1001299.00

三、LEFT JOIN(左连接)

语法与作用

SELECT 字段
FROM 表A
LEFT JOIN 表B ON 表A.字段 = 表B.字段;
  • 作用:返回左表所有记录,右表无匹配则显示NULL
  • 使用场景:统计所有用户的订单情况(包括未下单用户)

示例

查询:统计所有用户的订单(含未下单用户)

SELECT u.name, o.order_id, o.amount
FROM users u
LEFT JOIN orders o ON u.user_id = o.user_id;

结果

nameorder_idamount
张三1001299.00
李四NULLNULL

四、RIGHT JOIN(右连接)

语法与作用

SELECT 字段
FROM 表A
RIGHT JOIN 表B ON 表A.字段 = 表B.字段;
  • 作用:返回右表所有记录,左表无匹配则显示NULL
  • 使用场景:查找所有订单对应的用户(包括无效用户订单)

示例

查询:显示所有订单及用户信息

SELECT u.name, o.order_id, o.amount
FROM users u
RIGHT JOIN orders o ON u.user_id = o.user_id;

结果

nameorder_idamount
张三1001299.00
NULL1002599.00

五、FULL JOIN(全连接)

语法与作用(MySQL实现方式)

SELECT 字段
FROM 表A
LEFT JOIN 表B ON 表A.字段 = 表B.字段
UNION
SELECT 字段
FROM 表A
RIGHT JOIN 表B ON 表A.字段 = 表B.字段;
  • 作用:返回所有记录(类似LEFT JOIN + RIGHT JOIN去重)
  • 使用场景:需要同时保留两个表所有记录的统计

示例

查询:合并用户和订单的所有记录

SELECT u.name, o.order_id, o.amount
FROM users u
LEFT JOIN orders o ON u.user_id = o.user_id
UNION
SELECT u.name, o.order_id, o.amount
FROM users u
RIGHT JOIN orders o ON u.user_id = o.user_id;

结果

nameorder_idamount
张三1001299.00
李四NULLNULL
NULL1002599.00

六、复合条件 JOIN

多表关联

-- 三表关联示例
SELECT u.name,o.order_id,p.product_name
FROM users u
INNER JOIN orders o ON u.user_id = o.user_id
INNER JOIN products p ON o.product_id = p.product_id;

多条件关联

-- 日期范围关联
SELECT e.emp_name,d.dept_name,s.salary
FROM employees e
LEFT JOIN salaries s ON e.emp_id = s.emp_id AND s.effective_date BETWEEN '2023-01-01' AND '2023-12-31';

七、自连接(Self Join)

语法与作用

SELECT A.字段, B.字段
FROMAS A
JOINAS B ON A.关联字段 = B.关联字段;
  • 使用场景:层级数据查询(如员工与上级经理)

示例

表结构

-- 创建员工表(包含员工ID、姓名和直属上级ID)
CREATE TABLE employees (emp_id INT PRIMARY KEY,       -- 员工ID(主键)name VARCHAR(50),            -- 员工姓名manager_id INT               -- 直属上级的员工ID(引用emp_id)
);-- 插入示例数据(构建管理层级关系)
INSERT INTO employees VALUES
(1, 'CEO', NULL),   -- CEO没有上级(manager_id为NULL)
(2, 'CTO', 1),      -- CTO的上级是CEO(emp_id=1)
(3, '工程师', 2);    -- 工程师的上级是CTO(emp_id=2)

查询:显示员工及其上级

-- 查询员工及其对应上级姓名(包含无上级的员工)
SELECT e.name AS employee,   -- 员工姓名m.name AS manager     -- 上级姓名
FROM employees e
LEFT JOIN employees m     -- 自连接:将员工表同时作为员工和上级表使用ON e.manager_id = m.emp_id;  -- 通过manager_id关联上级信息

结果

employeemanager
CEONULL
CTOCEO
工程师CTO

八、常见错误与解决方法

1. 笛卡尔积问题

错误示例

SELECT * FROM users, orders;  -- 未指定关联条件

结果:用户数 × 订单数 条记录(如2用户×2订单=4条)

正确写法

SELECT * FROM users
JOIN orders ON users.user_id = orders.user_id;

2. 别名使用不当

错误示例

SELECT user_id FROM users u
JOIN orders o ON users.user_id = o.user_id;  -- 错误:未使用别名

正确写法

SELECT u.user_id FROM users u
JOIN orders o ON u.user_id = o.user_id;

九、最佳实践建议

  1. 优先使用 INNER JOIN:明确需要关联数据时使用
  2. 慎用 RIGHT JOIN:可通过调换表顺序改用 LEFT JOIN
  3. 使用表别名:提高可读性(如 users u
  4. 关联字段加索引:显著提升 JOIN 性能
  5. 避免 SELECT:明确列出需要字段

相关文章:

七、JOIN 语法详解与实战示例

一、JOIN 的作用与分类 JOIN 操作用于合并两个或多个表的行,基于表之间的关联字段。以下是常见的 JOIN 类型: JOIN 类型描述INNER JOIN返回两个表匹配的记录LEFT JOIN返回左表所有记录 右表匹配记录(右表无匹配则为NULL)RIGHT …...

Skynet入门(一)

概念 skynet 是一个为网络游戏服务器设计的轻量框架。但它本身并没有任何为网络游戏业务而特别设计的部分,所以尽可以把它用于其它领域。 设计初衷 如何充分利用它们并行运作数千个相互独立的业务。 模块设计建议 在 skynet 中,用服务 (service) 这…...

单片机栈和堆、FALSH、区别

1. Flash(闪存)(程序存储器) 用途 存储程序代码:编译后的机器指令(如 .text 段)、常量数据(如 .rodata 段)等。 掉电不丢失:程序固化在 Flash 中&#xff0…...

【FL0090】基于SSM和微信小程序的球馆预约系统

🧑‍💻博主介绍🧑‍💻 全网粉丝10W,CSDN全栈领域优质创作者,博客之星、掘金/知乎/b站/华为云/阿里云等平台优质作者、专注于Java、小程序/APP、python、大数据等技术领域和毕业项目实战,以及程序定制化开发…...

如何把word文档整个文档插入到excel表格里?

现象: 当我们双击此文档时可以快速打开对应的word文档 实现步骤: 1、点击一下要插入的excel表格里的单元格 2、选择上方的的【插入】【附件】的下拉框下的【对象】 3、选择【由文件创建】-【浏览】 再在弹出的框中选择【桌面】,选择要插…...

PDF文档中表格以及形状解析

我们在做PDF文档解析时有时需要解析PDF文档中的表格、形状等数据。跟解析文本类似的常见的解决方案也是两种。文档解析跟ocr技术处理。下面我们来看看使用文档解析的方案来做PDF文档中的表格、图形解析(使用pdfium库)。 表格解析: 在pdfium库…...

C++20 Lambda表达式新特性:包扩展与初始化捕获的强强联合

文章目录 一、Lambda表达式的历史回顾二、C20 Lambda表达式的两大新特性(一)初始化捕获(Init-Capture)(二)包扩展(Pack Expansion) 三、结合使用初始化捕获与包扩展(一&a…...

51c自动驾驶~合集52

我自己的原文哦~ https://blog.51cto.com/whaosoft/13383340 #世界模型如何推演未来的千万种可能 驾驶世界模型(DWM),专注于预测驾驶过程中的场景演变,已经成为追求自动驾驶的一种有前景的范式。这些方法使自动驾驶系统能够更…...

go设计模式

刘:https://www.bilibili.com/video/BV1kG411g7h4 https://www.bilibili.com/video/BV1jyreYKE8z 1. 单例模式 2. 简单工厂模式 代码逻辑: 原始:业务逻辑层 —> 基础类模块工厂:业务逻辑层 —> 工厂模块 —> 基础类模块…...

FREERTOS的三种调度方式

一、调度器的调度方式 调度器的调度方式解释针对的对象抢占式调度1.高优先级的抢占低优先级的任务 2.高优先级的任务不停止,低优先级的任务不能执行 3.被强占的任务会进入就绪态优先级不同的任务时间片调度1.同等优先级任务轮流享用CPU时间 2.没有用完的时间片&…...

前端依赖nrm镜像管理工具

npm 默认镜像 :https://registry.npmjs.org/ 1、安装 nrm npm install nrm --global2、查看镜像源列表 nrm ls3、测试当前环境下,哪个镜像源速度最快。 nrm test4、 切换镜像源 npm config get registry # 查看当前镜像源 nrm use taobao # 等价于 npm…...

redis repl_backlog_first_byte_offset 这个字段的作用

repl_backlog_first_byte_offset 是 Redis 复制积压缓冲区(Replication Backlog)中的一个关键字段,其作用是 标识积压缓冲区中第一个字节对应的全局复制偏移量。 通俗解释 当主从节点断开重连时,Redis 需要通过复制积压缓冲区&am…...

JavaScript基础(BOM对象、DOM节点、表单)

BOM对象 浏览器介绍 BOM:浏览器对象模型 IEChromeSafariFireFox 三方 QQ浏览器360浏览器 window对象 window代表浏览器窗口 window.innerHeight 734 window.innerWidth 71 window.outerHeight 823 window.outerWidth 782 Navigator对象(不常用&am…...

Java Junit框架

JUnit 是一个广泛使用的 Java 单元测试框架,用于编写和运行可重复的测试。它是 xUnit 家族的一部分,专门为 Java 语言设计。JUnit 的主要目标是帮助开发者编写可维护的测试代码,确保代码的正确性和稳定性。 JUnit 的主要特点 注解驱动&…...

23种设计模式之《备忘录模式(Memento)》在c#中的应用及理解

程序设计中的主要设计模式通常分为三大类,共23种: 1. 创建型模式(Creational Patterns) 单例模式(Singleton):确保一个类只有一个实例,并提供全局访问点。 工厂方法模式&#xff0…...

Seaborn知识总结

1、简介 (1)高级接口:Seaborn 提供了一组高级函数和方法,可以使得创建常见的统计图表变得简单,例如散点图、线性回归图、箱线图、直方图、核密度估计图、热图等等。无需像 Matplotlib 一样写大量的代码; …...

flowable中用户相关api

springboot引入flowable&#xff1a;高版本mysql报错 <!-- https://mvnrepository.com/artifact/org.flowable/flowable-spring-boot-starter --><dependency><groupId>org.flowable</groupId><artifactId>flowable-spring-boot-starter</art…...

java后端开发day23--面向对象进阶(四)--抽象类、接口、内部类

&#xff08;以下内容全部来自上述课程&#xff09; 1.抽象类 父类定义抽象方法后&#xff0c;子类的方法就必须重写&#xff0c;抽象方法在的类就是抽象类。 1.定义 抽象方法 将共性的行为&#xff08;方法&#xff09;抽取到父类之后。由于每一个子类执行的内容是不一样…...

安装 Open WebUI

2025.03.01 早上 我已经安装了ollama 和deeseek模型 &#xff08;本地部署流水账之ollama安装Deepseek安装-CSDN博客&#xff09;&#xff0c;然后需要个与模型沟通的工具&#xff08;这么说不知道对不对&#xff09;。 刚开始用的chatbox&#xff0c;安装很方便&#xff0c;…...

Llama 2中的Margin Loss:为何更高的Margin导致更大的Loss和梯度?

Llama 2中的Margin Loss&#xff1a;为何更高的Margin导致更大的Loss和梯度&#xff1f; 在《Llama 2: Open Foundation and Fine-Tuned Chat Models》论文中&#xff0c;作者在强化学习与人类反馈&#xff08;RLHF&#xff09;的Reward Model训练中引入了Margin Loss的概念&a…...

基于SpringBoot的运动会报名与成绩录入系统毕业设计

博主介绍&#xff1a;✌ 专注于Java,python,✌关注✌私信我✌具体的问题&#xff0c;我会尽力帮助你。一、研究目的本研究旨在构建一个基于Spring Boot与Vue框架的运动会报名与成绩录入系统以解决传统体育赛事管理中存在的信息处理效率低下数据准确性不足以及资源分配不科学等问…...

【Linux驱动开发】第12天:Linux设备树核心:树形结构+节点+属性 完整全解

目录 设备树树形结构概述节点&#xff08;Node&#xff09;全解&#xff1a;命名规范标准节点常用设备节点属性&#xff08;Property&#xff09;全解&#xff1a;类型核心属性总线专用属性标签与节点引用&#xff1a;设备树复用的核心常见错误与注意事项总结&#xff1a;驱动…...

瑞数6代JSVMP对抗实战:Node.js环境补全与412绕过

1. 这不是“绕过验证码”&#xff0c;而是一场Web前端对抗的深度解剖瑞数6代&#xff0c;业内常被称作“JSVMP黑盒”的典型代表——它不靠传统混淆堆砌代码体积&#xff0c;也不依赖简单的时间戳或行为采集做判断&#xff0c;而是把整个校验逻辑编译进一套自定义的、高度定制化…...

Unity低耦合可复用交互系统设计与实现

1. 为什么“交互系统”在Unity项目里总变成一锅粥&#xff1f;你有没有遇到过这样的场景&#xff1a;美术同事改了个按钮位置&#xff0c;UI脚本里硬编码的transform.Find("Button")就报空引用&#xff1b;策划临时加个新交互逻辑&#xff0c;程序员得翻遍PlayerCont…...

别再死记公式了!用Python和NumPy直观理解向量模长与矩阵范数

用Python和NumPy直观理解向量模长与矩阵范数 线性代数中的向量模长和矩阵范数常被视为抽象的数学符号&#xff0c;但它们在机器学习、图像处理和科学计算中扮演着核心角色。本文将用Python代码将这些概念可视化&#xff0c;让你在交互式实践中建立直觉理解。 1. 向量模长&#…...

为ClaudeCode配置Taotoken作为稳定后备API服务避免中断

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 为ClaudeCode配置Taotoken作为稳定后备API服务避免中断 基础教程类&#xff0c;针对担心Claude Code服务不稳定或配额不足的用户&a…...

Lindy流程冷启动死亡陷阱(97%新手踩中的第3个环节):实时检测+自动回滚机制详解

更多请点击&#xff1a; https://kaifayun.com 第一章&#xff1a;Lindy流程冷启动死亡陷阱的底层认知 Lindy效应在软件工程中并非仅适用于“越老越可靠”的技术寿命预测&#xff0c;它更深层地揭示了一种反直觉的系统演化规律&#xff1a;一个尚未被时间验证的流程&#xff0…...

避坑指南:用STM32F4的HAL库驱动L298N和TB6612,CubeMX配置有哪些关键点不同?

STM32F4电机驱动实战&#xff1a;L298N与TB6612的CubeMX配置差异全解析 在机器人底盘或智能小车开发中&#xff0c;电机驱动模块的选择直接影响着系统的响应速度、能耗效率和整体稳定性。作为两种经典的有刷直流电机驱动方案&#xff0c;L298N和TB6612在STM32F4开发中各有拥趸。…...

HTTPS抓包失败根因分析:证书信任链与全平台配置实战

1. 为什么HTTPS抓包不是“装个插件就完事”——从浏览器报错红锁说起你刚在Burp Suite里点开Proxy → Options → Import Burps CA Certificate&#xff0c;双击安装完证书&#xff0c;兴冲冲打开Chrome访问https://example.com&#xff0c;结果地址栏赫然挂着一把刺眼的红色锁…...

微信小程序wxapkg解密与AES密钥还原技术解析

1. 这不是“黑产教程”&#xff0c;而是一次面向安全研究者的合规技术复盘 “微信小程序逆向”这六个字&#xff0c;在很多开发者听来带着天然的警觉感——它常被误读为“破解他人代码”“窃取商业逻辑”甚至“绕过支付”。但真实情况恰恰相反&#xff1a;在合法授权前提下&…...