博客
关于我
mysql 内连接、自然连接、外连接的区别
阅读量:796 次
发布时间:2023-02-10

本文共 1160 字,大约阅读时间需要 3 分钟。

数据库中的连接操作主要包括内连接、自然连接和外连接,其中外连接又分为左外连接、右外连接和全外连接。这些连接操作的核心目的是从两个表中构建一个笛卡尔积,然后根据特定的条件筛选出符合要求的记录。

1. 自然连接(Natural Join)

自然连接是一种特殊的等值连接,其特点是两个表必须通过相同的属性列(即字段名完全一致)进行连接。与内连接不同,自然连接无需显式指定连接条件,并且会将重复的属性列从结果中去除。

示例:

SELECT * FROM table1 NATURAL JOIN table2

结果:该查询会返回两个表中字段名完全相同的记录,并去除重复的字段。

2. 内连接(Inner Join)

内连接允许两个表通过特定的字段进行连接,这些字段不需要完全相同。使用INNER JOIN或简写JOIN时,需要通过ON子句指定连接字段。

示例:

SELECT * FROM table1 INNER JOIN table2 ON table1.A = table2.E

结果:内连接会返回两个表中字段值匹配的记录,未匹配的记录会被舍弃。

3. 外连接

外连接允许表的一部分记录与另一表的记录进行连接,未匹配的记录则会保留。外连接分为左外连接、右外连接和全外连接。

3.1 左外连接(Left Outer Join)

左外连接会保留左表未能匹配的记录,右表对应的字段值为NULL

示例:

SELECT * FROM table1 LEFT OUTER JOIN table2 ON table1.C = table2.C

结果:左表的未匹配记录保留,右表对应字段值为NULL

3.2 右外连接(Right Outer Join)

右外连接会保留右表未能匹配的记录,左表对应的字段值为NULL

示例:

SELECT * FROM table1 RIGHT OUTER JOIN table2 ON table1.C = table2.C

结果:右表的未匹配记录保留,左表对应字段值为NULL

3.3 全外连接(Full Outer Join)

全外连接允许两个表的所有未匹配记录保留,未匹配的字段值为NULL。在MySQL中,全外连接不直接支持,但可以通过组合左外连接和右外连接的结果来实现。

示例:

SELECT * FROM table1 LEFT OUTER JOIN table2 ON table1.C = table2.CUNIONSELECT * FROM table1 RIGHT OUTER JOIN table2 ON table1.C = table2.C

结果:两个查询的结果会合并,保留所有未匹配的记录。

通过合理运用内连接、自然连接和外连接,可以有效地从两个表中构建所需的关联结果。

转载地址:http://ewbfk.baihongyu.com/

你可能感兴趣的文章
mysql 多字段删除重复数据,保留最小id数据
查看>>
MySQL 多表联合查询:UNION 和 JOIN 分析
查看>>
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>
mysql 字段合并问题(group_concat)
查看>>
mysql 字段类型类型
查看>>
MySQL 字符串截取函数,字段截取,字符串截取
查看>>
MySQL 存储引擎
查看>>
mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
查看>>
MySQL 存储过程参数:in、out、inout
查看>>
mysql 存在update不存在insert
查看>>
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>
Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
查看>>
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 实现主从复制/主从同步
查看>>
mysql 审核_审核MySQL数据库上的登录
查看>>
mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
查看>>
mysql 常用
查看>>