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

MySQL中的内连接和外连接

一、MySQL内连接(INNER JOIN)

内连接,又称为等值连接,是最常见的连接类型。它根据两个(或多个)表中具有相同列值的行来创建一个新的结果表。在内连接中,只有通过连接条件匹配的行才会被包含在结果集中。

1.1 基本语法

内连接的基本语法如下:

SELECT column_name(s)
FROM table1
INNER JOIN table2
ON table1.column_name = table2.column_name;

1.2 示例

假设我们有两个表:employeesdepartments

employees 表:

emp_idemp_namedept_id
1John1
2Jane1
3Mark2
4Anna2
5Steve3

departments 表:

dept_iddept_name
1HR
2IT
3Operations

使用内连接查询员工及其所属部门:

SELECT employees.emp_name, departments.dept_name
FROM employees
INNER JOIN departments
ON employees.dept_id = departments.dept_id;

结果集:

emp_namedept_name
JohnHR
JaneHR
MarkIT
AnnaIT
SteveOperations

二、MySQL外连接(OUTER JOIN)

外连接用于获取在至少一个表中存在的行,即使在另一个表中没有匹配的行。MySQL支持左外连接(LEFT OUTER JOIN)和右外连接(RIGHT OUTER JOIN)。

2.1 左外连接(LEFT OUTER JOIN)

左外连接会返回左表(table1)的所有行,以及与之匹配的右表(table2)的行。如果在右表中没有匹配的行,则结果集中将显示NULL值。

2.1.1 基本语法

左外连接的基本语法如下:

SELECT column_name(s)
FROM table1
LEFT OUTER JOIN table2
ON table1.column_name = table2.column_name;

2.1.2 示例

使用左外连接查询员工及其所属部门,并显示没有分配部门的员工:

SELECT employees.emp_name, departments.dept_name
FROM employees
LEFT OUTER JOIN departments
ON employees.dept_id = departments.dept_id;

2.2 右外连接(RIGHT OUTER JOIN)

右外连接会返回右表(table2)的所有行,以及与之匹配的左表(table1)的行。如果在左表中没有匹配的行,则结果集中将显示NULL值。

2.2.1 基本语法

右外连接的基本语法如下:

SELECT column_name(s)
FROM table1
RIGHT OUTER JOIN table2
ON table1.column_name = table2.column_name;

2.2.2 示例

使用右外连接查询所有部门及其员工,包括没有员工的部门:

SELECT employees.emp_name, departments.dept_name
FROM employees
RIGHT OUTER JOIN departments
ON employees.dept_id = departments.dept_id;
http://www.lryc.cn/news/66964.html

相关文章:

  • node学习手册
  • Java中的JSP是什么?如何实现JSP
  • c++之函数对象和谓词
  • 《Andorid开源》greenDao 数据库orm框架
  • Android类似微信聊天页面教程(Kotlin)五——选择发送图片
  • MongoDB:Win/Linux环境安装及一键部署脚本
  • KingbaseES V8R3 集群运维系列 -- failover切换后集群自动恢复
  • 【Selenium中】——全栈开发——如桃花来
  • Sarsa增强版之Sarsa-λ依然走迷宫
  • 生成 Cypher 能力:MOSS VS ChatGLM
  • 数据库的键和存储
  • 基于AT89C51单片机的并入串出乘法口诀的设计与仿真
  • 人生在世皆有过错,来一起看看Java中的异常吧!!!
  • linux 测试连接网络和端口 telnet
  • 一文快速入门体验 Hibernate
  • 【RabbitMQ】SpringAMQP
  • 错题汇总08
  • 使用urllib库简单入门
  • C++学习 Day11
  • python中函数与类 类中的方法-静态方法/动态方法
  • 基于trace_id实现ForkJoinPool的链路追踪
  • Qt推流程序(视频文件/视频流/摄像头/桌面转成流媒体rtmp+hls+webrtc)可在网页和播放器远程观看
  • ChatGPT入门到高级【第一章】
  • 云原生应用架构
  • rem、px、em的区别 -前端
  • 分享几款小白从零开始学习的会用到的工具/网站
  • 第八章 文件处理命令
  • LVS 负载均衡群集的 NAT 模式和 DR 模式
  • 自学自动化测试,第一份工作就18K,因为掌握了这些技术
  • C++ 类的继承与派生