(六)MySQL数据库-常用连接查询(UNION、JOIN)

博客基于CentOS7.5系统和MySQL 5.7.26版本,介绍了几种连接查询方式。包括UNION连接,可去交集去重;INNER JOIN内连接,取两表交集;LEFT JOIN左连接,含表a所有项及表b匹配项;RIGHT JOIN右连接,含表b所有项及表a匹配项,还指出MySQL不支持全外连接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

(六)MySQL数据库-常用连接查询(UNION、JOIN)

我的系统版本为CentOS7.5,MySQL版本为5.7.26

为了更清楚的说明各个连接查询的差异,新建两个表数据如下

在这里插入图片描述

UNION 连接

将两个SQL语句去交集去重

select name from a union select name from b;

在这里插入图片描述

INNER JOIN (内连接)

此语句的结果为同时匹配表a和表b的记录集。即内连接取的是两个表的交集,可以简写为JOIN

#以下两个语句等价
select a.id,a.name,b.age from a join b on a.name=b.name;
select a.id,a.name,b.age from a , b where a.name=b.name;

在这里插入图片描述

LEFT JOIN (左连接)

此语句的结果为表a的所有项加表b与a相匹配的项,b中没有与a匹配的项时显示为null

select a.id,a.name,b.age from a left join b on a.name=b.name;

在这里插入图片描述

RIGHT JOIN (右连接)

此语句的结果为表a与表b匹配的项加表b的所有项,a中没有与b匹配的项时显示为null

select a.id,a.name,b.age from a right join b on a.name=b.name;

在这里插入图片描述MySQL不支持全外连接

### MySQLJOIN 查询的执行方式 在 MySQL 数据库中,`JOIN` 是一种用于关联多个表数据的重要操作。它允许用户基于某些条件组合不同表中的记录。以下是关于 `JOIN` 的详细介绍: #### 1. 基本语法结构 `JOIN` 查询的基本语法如下所示: ```sql SELECT columns FROM table1 JOIN table2 ON table1.column = table2.column; ``` 其中,`table1` `table2` 表示参与连接的两张表,而 `ON` 子句定义了两表之间的匹配条件。 #### 2. 不同类型的 JOIN 及其用途 - **INNER JOIN**: 返回两个表中满足连接条件的交集部分[^2]。 ```sql SELECT t1.col, t2.col FROM table1 AS t1 INNER JOIN table2 AS t2 ON t1.id = t2.t1_id; ``` - **LEFT JOIN (或 LEFT OUTER JOIN)**: 返回左表的所有记录以及右表中符合条件的部分;如果右表无对应记录,则返回 NULL。 ```sql SELECT t1.col, t2.col FROM table1 AS t1 LEFT JOIN table2 AS t2 ON t1.id = t2.t1_id; ``` - **RIGHT JOIN (或 RIGHT OUTER JOIN)**: 类似于 LEFT JOIN,但它会保留右侧表的所有记录。 ```sql SELECT t1.col, t2.col FROM table1 AS t1 RIGHT JOIN table2 AS t2 ON t1.id = t2.t1_id; ``` - **FULL OUTER JOIN**: 虽然标准 SQL 支持 FULL OUTER JOIN,但在 MySQL 中并不支持此功能。可以通过 UNION 实现类似的逻辑。 #### 3. 性能优化建议 为了提高 JOIN 操作的效率,在设计查询时需注意以下几点: - 使用较小的结果集作为驱动表来减少不必要的计算量[^3]。 - 避免频繁创建销毁大量临时链接资源,这可能导致系统负载过高。 - 对于特定场景下可能存在的替代方案(如子查询),应评估它们相对于传统 JOIN 方法的表现差异[^4]。 #### 示例代码展示 下面提供了一个简单的例子说明如何利用 EXPLAIN 来分析查询计划并理解实际运行情况: ```sql EXPLAIN EXTENDED SELECT e.name, d.department_name FROM employees e INNER JOIN departments d ON e.dept_id = d.id; ``` 上述命令可以帮助开发者了解具体实现细节及其潜在瓶颈所在位置[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值