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)

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

相关推荐
恒悦sunsite3 小时前
Ubuntu之apt安装ClickHouse数据库
数据库·clickhouse·ubuntu·列式存储·8123
奥尔特星云大使4 小时前
MySQL 慢查询日志slow query log
android·数据库·mysql·adb·慢日志·slow query log
来自宇宙的曹先生4 小时前
MySQL 存储引擎 API
数据库·mysql
间彧4 小时前
MySQL Performance Schema详解与实战应用
数据库
间彧4 小时前
MySQL Exporter采集的关键指标有哪些,如何解读这些指标?
数据库
weixin_446260854 小时前
Django - 让开发变得简单高效的Web框架
前端·数据库·django
mpHH5 小时前
babelfish for postgresql 分析--todo
数据库·postgresql
zizisuo5 小时前
解决在使用Lombok时maven install 找不到符号的问题
java·数据库·maven
老苏畅谈运维6 小时前
Oracle的connect by level在MySQL中的华丽变身
mysql·oracle
程序边界6 小时前
国产之光!金仓数据库KingbaseES Oracle兼容性深度体验大赏
数据库·oracle