SQL表连接方式

一、SQL中的表连接方式:

  1. 内连接(INNER JOIN):返回两个表中符合连接条件的交集。
  2. 外连接(OUTER JOIN):
    • 左外连接(LEFT JOIN):返回左表中所有记录,以及右表中符合连接条件的记录。
    • 右外连接(RIGHT JOIN):返回右表中所有记录,以及左表中符合连接条件的记录。
    • 完全外连接(FULL JOIN):返回左表和右表中的所有记录,如果没有匹配的记录则用NULL填充。
  3. 交叉连接(CROSS JOIN):返回两个表的笛卡尔积,即左表中的每一行都与右表中的每一行组合。
  4. 自连接(SELF JOIN):将表与自身进行连接,常用于比较表中不同行之间的数据。

这些连接方式允许在不同的条件下将多个表关联起来,以满足查询的需求。

二、创建两个表:

employees(员工信息)和departments(部门信息):
sql 复制代码
CREATE TABLE departments (
    department_id INT PRIMARY KEY,
    department_name VARCHAR(50)
);

CREATE TABLE employees (
    employee_id INT PRIMARY KEY,
    employee_name VARCHAR(50),
    department_id INT,
    manager_id INT,
    FOREIGN KEY (department_id) REFERENCES departments(department_id),
    FOREIGN KEY (manager_id) REFERENCES employees(employee_id)
);

departments表有两个列:department_iddepartment_name,其中department_id是主键。

employees表有四个列:employee_idemployee_namedepartment_idmanager_id,其中employee_id是主键,department_id是外键关联到departments表的department_idmanager_id是外键关联到employees表的employee_id,表示员工的直接上级。

这样就创建了两个简单的表,可以用于存储员工和部门的信息。

插入数据:

sql 复制代码
-- 向 departments 表插入数据
INSERT INTO departments (department_id, department_name) VALUES
(1, 'IT'),
(2, 'HR'),
(3, 'Finance'),
(4, 'Marketing'),
(5, 'Sales');

-- 向 employees 表插入数据
INSERT INTO employees (employee_id, employee_name, department_id, manager_id) VALUES
(1, 'John Doe', 1, NULL),
(2, 'Jane Smith', 2, 1),
(3, 'David Lee', 1, 1),
(4, 'Emily Brown', 3, 1),
(5, 'Michael Johnson', 4, 3),
(6, 'Lisa Wang', 1, 3),
(7, 'Tom Davis', 5, 4),
(8, 'Sarah White', 5, 4),
(9, 'Kevin Martin', 2, 1),
(10, 'Mary Wilson', 3, 1);

三、演示连接方式:

1.内连接(INNER JOIN):

sql 复制代码
SELECT e.employee_name, e.employee_id, d.department_name
FROM employees e
INNER JOIN departments d ON e.department_id = d.department_id;

结果:

sql 复制代码
employee_name   | employee_id | department_name
-----------------------------------------------
John Doe        | 1           | IT
Jane Smith      | 2           | HR
David Lee       | 3           | IT
Emily Brown     | 4           | Finance
Michael Johnson | 5           | Marketing
Lisa Wang       | 6           | IT
Tom Davis       | 7           | Sales
Sarah White     | 8           | Sales
Kevin Martin    | 9           | HR
Mary Wilson     | 10          | Finance

2.左外连接(LEFT JOIN):

sql 复制代码
SELECT e.employee_name, e.employee_id, d.department_name
FROM employees e
LEFT JOIN departments d ON e.department_id = d.department_id;

结果:

sql 复制代码
employee_name   | employee_id | department_name
-----------------------------------------------
John Doe        | 1           | IT
Jane Smith      | 2           | HR
David Lee       | 3           | IT
Emily Brown     | 4           | Finance
Michael Johnson | 5           | Marketing
Lisa Wang       | 6           | IT
Tom Davis       | 7           | Sales
Sarah White     | 8           | Sales
Kevin Martin    | 9           | HR
Mary Wilson     | 10          | Finance

3.右外连接(RIGHT JOIN):

sql 复制代码
SELECT e.employee_name, e.employee_id, d.department_name
FROM employees e
RIGHT JOIN departments d ON e.department_id = d.department_id;

结果:

sql 复制代码
employee_name   | employee_id | department_name
-----------------------------------------------
John Doe        | 1           | IT
Jane Smith      | 2           | HR
David Lee       | 3           | IT
Emily Brown     | 4           | Finance
Michael Johnson | 5           | Marketing
Lisa Wang       | 6           | IT
Tom Davis       | 7           | Sales
Sarah White     | 8           | Sales
Kevin Martin    | 9           | HR
Mary Wilson     | 10          | Finance

4.交叉连接(CROSS JOIN):

sql 复制代码
SELECT e.employee_name, d.department_name
FROM employees e
CROSS JOIN departments d;

结果会返回所有可能的员工和部门组合,共50条记录(10个员工 * 5个部门)。

5.自连接(SELF JOIN):

假设我们想要查找每个员工的经理,我们可以使用自连接:

sql 复制代码
SELECT e.employee_name, m.employee_name AS manager_name
FROM employees e
LEFT JOIN employees m ON e.manager_id = m.employee_id;

这将返回每个员工及其对应的经理的姓名。

相关推荐
煎蛋学姐1 分钟前
SSM社区志愿者服务系统d6d36(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·社区志愿者服务系统
语落心生34 分钟前
解读广告数仓(二)数据架构与关键系统设计
数据库
冉冰学姐34 分钟前
SSM实验室安全管理系统c03w5(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架应用·实验室安全管理·数字化管理系统
松☆35 分钟前
OpenHarmony + Flutter 混合开发实战:构建高性能离线优先的行业应用(含 SQLite 与数据同步策略)
数据库·flutter·sqlite
语落心生39 分钟前
解读广告数仓(四) - 指标计算与应用实现
数据库
语落心生42 分钟前
解读广告数仓(一) - 广告业务模型与指标体系深化分析
数据库
老华带你飞1 小时前
旅游|基于Java旅游信息推荐系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端·旅游
冉冰学姐1 小时前
SSM石家庄铁道大学影视资料管理系统ql5pa(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm框架·石家庄铁道大学
Sunhen_Qiletian1 小时前
《Python开发之语言基础》第七集:库--时间库
前端·数据库·python
程序边界1 小时前
金仓数据库助力Oracle迁移实战:破局四大挑战,解锁高效迁移新路径
数据库·oracle