【MySQL】 复合查询 | 内外连接
复合查询中的内外连接是非常常见的操作,它们可以帮助我们从多个相关表中提取数据。内连接(INNER JOIN)仅选择两个表中有匹配的记录,而外连接(OUTER JOIN)则选择一个表中的所有记录,即使另一个表中没有匹配的记录。
以下是使用MySQL内外连接的示例代码:
-- 创建示例表
CREATE TABLE employees (
id INT PRIMARY KEY,
name VARCHAR(50),
department_id INT
);
CREATE TABLE departments (
id INT PRIMARY KEY,
name VARCHAR(50)
);
-- 插入示例数据
INSERT INTO employees (id, name, department_id) VALUES (1, 'Alice', 1), (2, 'Bob', 2);
INSERT INTO departments (id, name) VALUES (1, 'HR'), (2, 'IT');
-- 内连接查询
SELECT employees.name, departments.name
FROM employees
INNER JOIN departments ON employees.department_id = departments.id;
-- 外连接查询(左连接,显示所有员工及其部门信息,即使某些员工没有对应的部门)
SELECT employees.name, departments.name
FROM employees
LEFT JOIN departments ON employees.department_id = departments.id;
-- 外连接查询(右连接,显示所有部门及其员工信息,即使没有员工在该部门)
SELECT employees.name, departments.name
FROM employees
RIGHT JOIN departments ON employees.department_id = departments.id;
这个例子中,我们创建了两个表employees
和departments
,并插入了一些示例数据。然后我们展示了如何使用内连接查询来选择两个表中匹配的记录,以及如何使用左连接和右连接来查询所有员工及其部门信息,或者所有部门及其员工信息,即使其中一个表中没有匹配的记录。
评论已关闭