【PostgreSQL】提高篇——深入了解不同类型的 JOIN(INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL JOIN)应用操作

1. JOIN 的基础概念

在 SQL 中,JOIN 是用于从两个或多个表中组合行的操作。JOIN 允许我们根据某些条件将表中的数据关联在一起。常见的 JOIN 类型包括:

  • INNER JOIN:仅返回两个表中满足连接条件的行。
  • LEFT JOIN(或 LEFT OUTER JOIN):返回左表中的所有行,以及右表中满足条件的行;如果右表没有匹配,则结果为 NULL。
  • RIGHT JOIN(或 RIGHT OUTER JOIN):返回右表中的所有行,以及左表中满足条件的行;如果左表没有匹配,则结果为 NULL。
  • FULL JOIN(或 FULL OUTER JOIN):返回两个表中的所有行,如果没有匹配,则结果中对应的列为 NULL。

2. 各种 JOIN 的详细讲解

2.1 INNER JOIN

描述

INNER JOIN 是最常用的 JOIN 类型。它返回两个表中满足连接条件的行。只有在两个表中都有匹配的情况下,结果集才会包含该行。

语法
SELECT columns
FROM table1
INNER JOIN table2 ON table1.column = table2.column;
示例

假设有两个表:employees(员工)和 departments(部门)。

CREATE TABLE employees (
    employee_id INT,
    employee_name VARCHAR(100),
    department_id INT
);

CREATE TABLE departments (
    department_id INT,
    department_name VARCHAR(100)
);

-- INNER JOIN 示例
SELECT e.employee_name, d.department_name
FROM employees e
INNER JOIN departments d ON e.department_id = d.department_id;

在这个示例中,查询将返回所有有部门的员工及其对应的部门名称。

应用场景
  • 当需要从多个表中获取只有在所有表中都有的匹
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值