news 2026/3/5 2:19:44

4.5.4.数据查询连接

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
4.5.4.数据查询连接

在关系型数据库中,连接(Join)是 SQL 查询中最常用的操作之一,它用于在两个或多个表之间建立逻辑关系,将相关数据组合成一个结果集。

理解连接机制对于优化查询性能、设计高效数据库结构非常重要。

1.SQL连接的基本概念

连接(Join是指根据表之间的某种关联条件(通常是主键-外键关系或其他匹配条件),把多张表的数据组合成一个综合的结果集。

目的:将多个表的数据关联查询,避免数据冗余,提高数据结构的规范化。

条件:通常使用 ON 或 USING 指定匹配字段。

返回结果:每一行通常是多表匹配字段的笛卡尔积过滤结果。

2.SQL连接的类型

SQL连接主要分为以下几种类型:

2.1.内连接(INNER JOIN)

概念:只返回在两张表中匹配的行。

SQL 语法:

SELECTA.id, A.name, B.salary

FROMEmployee A

INNER JOINSalary B

ONA.id = B.emp_id;

机制:

1)对两个表进行匹配(通常根据索引或全表扫描)。

2)仅保留满足 ON 条件的记录。

应用场景:

只需要匹配的数据,不关心缺失值。

2.2.左连接(LEFT JOIN / LEFT OUTER JOIN)

概念:返回左表的所有行,即使右表没有匹配的行,右表字段显示为NULL

SQL 语法:

SELECT A.id, A.name, B.salary

FROM Employee A

LEFT JOINSalary B

ONA.id = B.emp_id;

机制:

遍历左表每一行。

查找右表中满足条件的行,如果没有匹配,右表字段填充 NULL。

应用场景:

左表数据完整性重要,需要显示未匹配右表的记录。

2.3.右连接(RIGHT JOIN / RIGHT OUTER JOIN)

概念:返回右表的所有行,即使左表没有匹配,左表字段显示为 NULL。

SQL 语法:

SELECT A.id, A.name, B.salary

FROM Employee A

RIGHT JOINSalary B

ON A.id = B.emp_id;

应用场景:右表数据完整性重要,需要显示未匹配左表的记录。

注意:左连接和右连接可以互换,主要看哪个表为“主表”。

2.4.全连接(FULL OUTER JOIN

概念:返回左右表的所有行,匹配的显示值,不匹配的用 NULL 补充。

SQL 语法(部分数据库如 MySQL 需用 UNION 实现):

SELECT A.id, A.name, B.salary

FROM Employee A

LEFT JOIN Salary B ON A.id = B.emp_id

UNION

SELECT A.id, A.name, B.salary

FROM Employee A

RIGHT JOIN Salary B ON A.id = B.emp_id;

应用场景:需要完整显示两张表的数据,无论是否匹配。

2.5.自连接(SELF JOIN

概念:表与自身连接,通常用于层级关系或比较。

SQL 语法:

SELECT A.name AS Employee, B.name AS Manager

FROM Employee A

INNER JOIN Employee B

ON A.manager_id = B.id;

应用场景:处理树状、层级结构,如员工-经理关系、分类-子类关系。

2.6.交叉连接(CROSS JOIN

概念:返回两张表的笛卡尔积(所有行的组合),无连接条件。

SQL 语法:

desc yonghu;

select A.id,B.addtime

FROM yonghu A

CROSS JOINyonghuzu B;

应用场景:需要生成所有组合情况,例如测试、组合分析。

4.性能优化建议

1)使用合适的连接类型

避免不必要的全连接和笛卡尔积,尽量用INNER JOINLEFT JOIN

2)创建索引

对连接字段建立索引,提升查找速度。

3)减少数据量

连接前先筛选数据(使用 WHERE 或子查询)。

4)选择小表驱动大表

在嵌套循环中,把小表作为外层表,提高效率。

5)分析执行计划

使用EXPLAIN或数据库执行计划工具,查看连接策略和扫描方式,调整查询结构。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/27 12:10:34

小程序计算机毕设之基于SpringBoot+微信小程序的微信刷题系统管理系统基于springboot+微信小程序的在线复习小程序(完整前后端代码+说明文档+LW,调试定制等)

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/2/28 14:09:52

小程序计算机毕设之基于springboot+微信小程序的钓鱼交友与渔具回收的微信小程序开发钓点信息、天气预报、文章信息、联系钓友、商城管理(完整前后端代码+说明文档+LW,调试定制等)

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/2/28 12:30:39

小程序毕设选题推荐:基于springboot+微信小程序的钓鱼交友与渔具回收的微信小程序开发基于微信小程序的钓鱼论坛小程序系统【附源码、mysql、文档、调试+代码讲解+全bao等】

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/3/1 12:23:52

Github Copilot 实战: 使用 Copilot AI + Blazor 编一个五子棋游戏

创建 Blazor web工程,选Autoimage2. 打开 GitHub Copilot 窗口,输入提示词使用 Blazor 编一个五子棋游戏image3.复制代码测试为了方便调试, 我们先把运行模式由 InteractiveAuto 改为 InteractiveServer打开 App.razor 编辑 两行 rendermode"InteractiveAuto" 改为 r…

作者头像 李华
网站建设 2026/2/28 6:25:36

【课程设计/毕业设计】基于微信小程序的应急救援小能手软件系统基于springboot+微信小程序的应急救援小能手软件系统的设计与实现【附源码、数据库、万字文档】

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/2/28 1:23:58

【课程设计/毕业设计】基于Springboot+微信小程序的校园二手交易平台小程序基于springboot+微信小程序的社区论坛与二手交易平台的设计与实现【附源码、数据库、万字文档】

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华