MySQL——连接查询(2)内连接

内连接(Inner Join)又称简单连接或自然连接,是一种常见的连接查询。内连接使用比较运算符对两个表中的数据进行比较,并列出与连接条件匹配的数据行,组合成新的记录,也就是说在内连接查询中,只有满足条件的记录才能出现在查询结果中。内连接查询的语法格式如下所示:

sql 复制代码
SELECT 查询字段 FROM 表1 [INNER] JOIN 表2 0N 表1.关系字段=表2.关系字段

在上述语法格式中,INNER JOIN 用于连接两个表,ON 来指定连接条件,其中INNER 可以省略。

例如,在 department 表和 employee 表之间使用内连接查询,SQL 语句如下:

sql 复制代码
SELECT employee.name,department.dname FROM department JOIN employee ON department.did=employee.did;

上述语句执行成功后,结果如下:

sql 复制代码
mysql> SELECT employee.name,department.dname FROM department JOIN employee ON department.did=employee.did;
+--------+-----------+
| name   | dname     |
+--------+-----------+
| 小红   | 网络部    |
| 小强   | 网络部    |
| 小明   | 媒体部    |
+--------+-----------+
3 rows in set (0.00 sec)

从上述结果可以看出,只有 department.did 与 employee.did 相等的员工才会被显示。

在 MySQL 中,还可以使用 where 条件语句来实现同样的功能。

例如,在 department 表和 employee 表之间使用 WHERE,SQL语句如下:

sql 复制代码
SELECT employee.name,department.dname FROM department,employee WHERE department.did=employee.did;

上述语句执行成功后,结果如下:

sql 复制代码
mysql> SELECT employee.name,department.dname FROM department,employee WHERE department.did=employee.did;
+--------+-----------+
| name   | dname     |
+--------+-----------+
| 小红   | 网络部    |
| 小强   | 网络部    |
| 小明   | 媒体部    |
+--------+-----------+
3 rows in set (0.00 sec)

从查询结果可以看出,使用 WHERE 子句的查询结果与使用INNER JOIN 的查询"果是一致的。需要注意的是,这两个语句的查询结果虽然相同,但是INNER JOIN 是的莲接语句,WHERE 是条件判断语句,在 WHERE 语句后可以直接添加其他条件,而NNER JOIN 语句不可以。

如果在一个连接查询中,涉及的两个表是同一个表,这种查询称为自连接查询。自"接是一种特殊的内连接,它是指相互连接的表在物理上为同一个表,但逻辑上分为两表,例如要查询小红所在的部门有哪些员工,就可以使用自连接查询。

例如,在 department 表和 employee 表之间使用自连接查询,SQL语句如下:

sql 复制代码
SELECT p1.* FROM employee p1 JOIN employee p2 ON p1.did=p2.did WHERE p2.name='小红';

上述语句执行成功后,结果如下:

sql 复制代码
mysql> SELECT p1.* FROM employee p1 JOIN employee p2 ON p1.did=p2.did WHERE p2.name='小红';
+----+--------+------+-----+
| id | name   | age  | did |
+----+--------+------+-----+
|  1 | 小红   |   20 |   1 |
|  2 | 小强   |   22 |   1 |
+----+--------+------+-----+
2 rows in set (0.00 sec)

从查询结果可以看出,王红所在的部门有两个员工,分别是小红和小强。

相关推荐
这个DBA有点耶4 小时前
NULL不是空——数据库里最反直觉的设计,90%新人踩过的坑
数据库·mysql·代码规范
这个DBA有点耶6 小时前
AI写的SQL跑崩了生产库,这锅谁背?
数据库·人工智能·程序员
镜舟科技6 小时前
Databricks 再提 LTAP,AI 时代的数据底座为何重回大一统叙事?
数据库·架构·agent
Databend7 小时前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence10 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
先吃饱再说1 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils1 天前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend1 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶1 天前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung1 天前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql