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

SQL 中如何实现多表关联查询?

       阅读本文之前请参阅----MySQL 数据库安装教程详解(linux系统和windows系统)

               在SQL中,多表关联查询是通过使用`JOIN`操作来实现的,它允许你从两个或多个表中根据相关列的值来检索数据。以下是几种常见的`JOIN`类型:
        1. **INNER JOIN**:只返回两个表中都有匹配的行。

 
   SELECT column1, column2, ...
   FROM table1
   INNER JOIN table2
   ON table1.common_column = table2.common_column;


        2. **LEFT JOIN(或LEFT OUTER JOIN)**:返回左表(table1)的所有行,即使右表(table2)中没有匹配。如果右表中没有匹配,则结果集中右表的部分返回NULL。


   SELECT column1, column2, ...
   FROM table1
   LEFT JOIN table2
   ON table1.common_column = table2.common_column;


        3. **RIGHT JOIN(或RIGHT OUTER JOIN)**:与LEFT JOIN相反,返回右表的所有行,即使左表中没有匹配。如果左表中没有匹配,则结果集中左表的部分返回NULL。


   SELECT column1, column2, ...
   FROM table1
   RIGHT JOIN table2
   ON table1.common_column = table2.common_column;


        4. **FULL JOIN(或FULL OUTER JOIN)**:返回两个表中所有的行。当某行在另一个表中没有匹配时,则结果集中该表的部分返回NULL。需要注意的是,并非所有的数据库系统都支持FULL JOIN。


   SELECT column1, column2, ...
   FROM table1
   FULL JOIN table2
   ON table1.common_column = table2.common_column;


        5. **CROSS JOIN**:返回两个表的笛卡尔积,即每个表中的每行与另一个表中的每行组合。如果没有WHERE子句或者ON子句来过滤结果,CROSS JOIN将返回两个表的行数的乘积。

  
   SELECT column1, column2, ...
   FROM table1
   CROSS JOIN table2;


        在执行多表关联查询时,你还可以使用`WHERE`子句来添加额外的过滤条件,以及使用`GROUP BY`、`HAVING`和`ORDER BY`子句来对结果进行分组、过滤和排序。
示例:假设有两个表,一个是`employees`表,包含员工信息,另一个是`departments`表,包含部门信息。我们可以使用INNER JOIN来获取每个员工的部门信息。


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


        在这个例子中,`employees.department_id`和`departments.id`是两个表之间的共同列,用于关联两个表的数据。

相关文章:

  • 【达梦数据库】数据库的方言问题导致的启动失败
  • 【pytorch】pytorch模型可复现设置
  • 5 buuctf解题
  • python 提取PDF文字
  • django自定义后端过滤
  • 【精选】网络安全大厂面试题 2.0
  • 物联网在智慧景区中的应用:提升游客体验与运营效率
  • 中国农业无人机行业市场现状分析与投资前景预测研究报告
  • This dependency was not found解决方法
  • 大数据之Flink优化
  • C 标准库 - <stdlib.h>
  • 抽象的java
  • 电路设计(28)——交通灯控制器的multisim仿真
  • 时间获取、文件属性获取 2月20日学习笔记
  • 【MySQL】数据类型——MySQL的数据类型分类、数值类型、小数类型、字符串类型
  • C# 实现网页内容保存为图片并生成压缩包
  • VoIP(Voice over Internet Protocol 基于IP的语音传输)介绍(网络电话、ip电话)
  • [Angular 基础] - 自定义指令,深入学习 directive
  • 【Java】类与对象(实验二)
  • Meta AI | 指令回译:如何从大量无标签文档挖掘高质量大模型训练数据?