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

mysql表连接方式

在 MySQL 中,表连接(Table Join)是将多个表中的数据通过关联条件组合在一起的核心操作

1. 内连接(INNER JOIN)

作用:返回两个表中 满足连接条件 的行(交集)。 

  • 仅返回匹配的行。

  • 如果某行在其中一个表中没有匹配项,则该行不显示。

 

 

 

 2. 左连接(LEFT JOIN / LEFT OUTER JOIN)

 作用:返回左表(LEFT JOIN左侧的表)所有行,右表中 匹配的行,若右表无匹配则填充 NULL

  • 左表数据完整保留,右表无匹配时显示 NULL

  • 常用于查找“左表存在但右表不存在”的数据。

 SELECT employees.name, departments.department_name
FROM employees
LEFT JOIN departments ON employees.department_id = departments.department_id;

 3. 右连接(RIGHT JOIN / RIGHT OUTER JOIN)

 作用:返回右表所有行,左表中 匹配的行,若左表无匹配则填充 NULL

  • 右表数据完整保留,左表无匹配时显示 NULL

  • 用途与 LEFT JOIN 类似,但方向相反。

 SELECT employees.name, departments.department_name
FROM employees
RIGHT JOIN departments ON employees.department_id = departments.department_id;

 4. 全外连接(FULL OUTER JOIN)

  • 返回所有数据,无论是否匹配。

  • 适用于需要同时保留两表全部数据的场景。

 SELECT employees.name, departments.department_name
FROM employees
LEFT JOIN departments ON employees.department_id = departments.department_id
UNION
SELECT employees.name, departments.department_name
FROM employees
RIGHT JOIN departments ON employees.department_id = departments.department_id;

 5. 交叉连接(CROSS JOIN)

  • 结果行数 = 左表行数 × 右表行数。

  • 慎用,可能导致海量数据。

 SELECT products.product_name, categories.category_name
FROM products
CROSS JOIN categories;

 

总结

连接类型描述常用场景
INNER JOIN返回匹配行精确关联查询
LEFT JOIN保留左表全部行查找左表存在但右表缺失的数据
RIGHT JOIN保留右表全部行查找右表存在但左表缺失的数据
FULL OUTER JOIN保留两表全部行(需模拟)合并两表所有数据
CROSS JOIN笛卡尔积生成组合数据(谨慎使用)
http://www.dtcms.com/a/103773.html

相关文章:

  • MSYS2学习笔记
  • Unity 2022.3.x部分Android设备播放视频黑屏问题
  • 华为三进制逻辑与高维量子计算的对比分析
  • 微服务面试题:配置中心
  • Docker学习--容器生命周期管理相关命令--start/stop/restart命令
  • 装饰器模式:如何用Java打扮一个对象?
  • 安卓应用开发学习:查看手机传感器信息
  • 流量监控工具iptraf-ng学习
  • cisco单臂路由配置
  • 服务器是指什么,都有哪些用途?
  • python将pdf文件转为图片,如果pdf文件包含多页,将转化的多个图片通过垂直或者水平合并成一张图片
  • 状态模式_行为型_GOF23
  • UE5学习笔记 FPS游戏制作27 显示玩家血量
  • python3的多进程和多线程设计实现
  • 力扣刷题-热题100题-第28题(c++、python)
  • RabbitMQ快速上手
  • 22--交换安全与端口隔离完全指南:MAC地址的奇幻漂流
  • 查看pip3 是否安装了Flask
  • MySQL8.0.37组复制MGR配置详解
  • 零基础被迫参加CTF比赛?CTF高频解题技巧与经验分享
  • 深入了解 MySQL 锁机制
  • 饮料购物商城基于Spring Boot SSM
  • java 面试题记录
  • C++ 变量的声明与定义分离式编译与静态类型(十六)
  • 基于 SpringBoot 的火车订票管理系统
  • 万字长文详解Text-to-SQL
  • 从 0 到跑通的 Qt + OpenGL + VS 项目的完整流程
  • 算法刷题记录——LeetCode篇(1.5) [第41~50题](持续更新)
  • Neo4j【环境部署 03】插件APOC和ALGO配置使用实例分享(网盘分享3.5.5兼容版本插件)
  • 【Windows】win10系统安装.NET Framework 3.5(包括.NET 2.0和3.0)失败 错误代码:0×80240438