news 2026/3/28 9:05:25

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/3/27 10:50:19

【课程设计/毕业设计】基于springboot+微信小程序的在线复习小程序基于SpringBoot的在线题库微信小程序系统【附源码、数据库、万字文档】

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

作者头像 李华
网站建设 2026/3/28 8:14:30

python练习项目

项目名称:简易学生成绩管理系统 功能要求: 主菜单:循环显示「1-添加成绩 2-查询成绩 3-统计分析 4-退出」;添加成绩:输入姓名成绩(校验0-100),追加写入student_grade.txt&#xff…

作者头像 李华
网站建设 2026/3/26 17:12:47

电动汽车负荷随机性下的蓄电池容量优化配置:MATLAB实现与探索

MATLAB代码:考虑电动汽车负荷随机性的蓄电池容量优化配置 关键词:蓄电池容量优化配置 储能优化配置 中长期配置 并网波动性 参考文档:《不确定环境下并网型光储微电网的容量规划》《考虑电动汽车有序充电的光储充电站储能容量优化策略_李景…

作者头像 李华
网站建设 2026/3/27 15:23:40

让YOLO飞起来:从CPU到GPU的配置指南

最近在配置YOLO(You Only Look Once)进行物体检测和图像分割任务时,发现默认安装的情况下,YOLO使用的是CPU进行计算。这对于需要处理大量图像或实时检测的任务来说,效率明显不足。本文将详细介绍如何将YOLO从CPU模式切…

作者头像 李华
网站建设 2026/3/27 15:19:39

磁链观测器:从仿真到闭环代码实现

磁链观测器(仿真+闭环代码参考文档) 1.仿真采用simulink搭建,2018b版本 2.代码采用Keil软件编译,思路参考vesc中使用的方法,自己编写的代码能够实现0速闭环启动,并且标注有大量注释,方便学习。 …

作者头像 李华
网站建设 2026/3/27 7:04:28

单机版RS485集中抄表软件:探索电表数据采集的奥秘

单机版RS485集中抄表软件,集中抄读645-2007协议的智能电表,645-1997的没有测试过,不清楚能不能抄,本地485有线集中抄表,配合485转网络可实现远程抄表在电力数据采集领域,单机版RS485集中抄表软件发挥着至关…

作者头像 李华