热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

SQL连接详解与应用

本文详细介绍了SQL连接的概念、分类及实际应用,包括内连接、外连接、自连接等,并提供了丰富的示例代码。

篇首语:本文由编程笔记小编整理,主要介绍了 SQL 连接的相关知识,希望对您有所帮助。



 


查询:子查询(嵌套查询)



 



连接查询

1. 什么是连接查询
关系型数据库中,表与表之间存在关联关系。为了获取多张表中的数据,通常需要使用连接查询。这种多表联合获取数据的方式称为连接查询。
在实际开发中,通过单表获取数据的情况较少见。

2. 连接查询的分类
- 按照连接方式分类
* 内连接(INNER JOIN)
内连接查询两张表中完全匹配的记录。常见的内连接类型包括等值连接、非等值连接和自连接。
* 外连接(OUTER JOIN)
外连接在内连接的基础上,显示一张表中的所有记录,即使另一张表中没有匹配的记录,也会用空值填充。外连接分为左外连接(LEFT OUTER JOIN)和右外连接(RIGHT OUTER JOIN)。
- 按照语法出现的年代分类
* SQL92标准
* SQL99标准

3. 如果不加连接条件会出现什么情况?
如果不加连接条件,查询结果将是笛卡尔积,即每张表中的每一行都会与其他表中的每一行组合。

4. 如何避免笛卡尔积?
在连接时加上适当的查询条件可以避免笛卡尔积。虽然这不会减少匹配的次数,但可以显著减少结果集的大小。

5. 案例:查询员工所在的部门,要求显示员工编号、员工姓名以及对应的部门编号和部门名称
涉及表:emp e(员工表),dept d(部门表)
- SQL92标准的等值连接
SELECT e.empno, e.ename, d.deptno, d.dname FROM emp e, dept d WHERE e.deptno = d.deptno;
- SQL99标准的等值连接(INNER可以省略)
SELECT e.empno, e.ename, d.deptno, d.dname FROM emp e INNER JOIN dept d ON e.deptno = d.deptno;
SQL92和SQL99的比较:
SQL92:连接条件和查询条件混合在一起,可读性较差。
SQL99:连接条件和查询条件分开,语句更清晰。

6. 案例:查询员工的工资对应的等级,要求显示员工的编号、员工姓名以及对应的工资等级
涉及表:emp e(员工表),salgrade s(工资等级表)
- SQL92标准的非等值连接
SELECT e.empno, e.ename, e.sal, s.grade FROM emp e, salgrade s WHERE e.sal BETWEEN s.losal AND s.hisal;

SELECT e.empno, e.ename, e.sal, s.grade FROM emp e, salgrade s WHERE e.sal >= s.losal AND e.sal <= s.hisal;
- SQL99标准的非等值连接
SELECT e.empno, e.ename, e.sal, s.grade FROM emp e JOIN salgrade s ON e.sal BETWEEN s.losal AND s.hisal;

7. 案例:查询员工对应的上级领导,要求显示员工的编号、员工姓名以及对应的上级领导的姓名
涉及表:emp e(员工表),emp m(领导表)
- SQL92标准的自连接
SELECT e.empno, e.ename, m.ename FROM emp e, emp m WHERE e.mgr = m.empno;
- SQL99标准的自连接
SELECT e.empno, e.ename, m.ename FROM emp e JOIN emp m ON e.mgr = m.empno;

8. 案例:查询员工所在的部门,要求显示员工编号、员工姓名以及对应的部门编号和部门名称,显示所有的部门
涉及表:emp e(员工表),dept d(部门表)
任何左外连接都对应一个右外连接。
- SQL99标准的左外连接
SELECT e.empno, e.ename, d.deptno, d.dname FROM dept d LEFT JOIN emp e ON e.deptno = d.deptno;
- SQL99标准的右外连接
SELECT e.empno, e.ename, d.deptno, d.dname FROM emp e RIGHT JOIN dept d ON e.deptno = d.deptno;
- SQL92标准的左外连接
SELECT e.empno, e.ename, d.deptno, d.dname FROM emp e, dept d WHERE d.deptno = e.deptno(+);
- SQL92标准的右外连接
SELECT e.empno, e.ename, d.deptno, d.dname FROM emp e, dept d WHERE e.deptno(+) = d.deptno;

9. 案例:查询员工的上级领导,要求显示员工的编号、员工姓名以及对应的上级领导的姓名,显示所有员工
- SQL99标准的左外连接
SELECT e.empno, e.ename, NVL(m.ename, '这是Boss') FROM emp e LEFT JOIN emp m ON e.mgr = m.empno;

10. 多张表如何进行连接查询?例如 a b c 表,a -> b 和 a -> c 的连接
以学生选课系统为例:
学生表 t_student s
id name
----------------------
1 张三
2 李四
3 王五
课程表 t_course c
id name
-----------------
100 C++
200 Java
300 Jsp
学生选课表 t_student_course_relation sc
sid cid (sid 是外键,关联学生表的主键;cid 也是外键,关联课程表的主键;sid + cid 是联合主键)
---------------------------------------------------
1 100
1 200
1 300
2 100
2 300
3 200
要求:编写查询语句,将2号学生选的课程查询出来,显示学生的姓名和课程名称
SELECT s.name, c.name FROM t_student_course_relation sc JOIN t_student s ON s.id = sc.sid JOIN t_course c ON c.id = sc.cid WHERE s.id = 2;


推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • PHP 编程疑难解析与知识点汇总
    本文详细解答了 PHP 编程中的常见问题,并提供了丰富的代码示例和解决方案,帮助开发者更好地理解和应用 PHP 知识。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • MySQL中枚举类型的所有可能值获取方法
    本文介绍了一种在MySQL数据库中查询枚举(ENUM)类型字段所有可能取值的方法,帮助开发者更好地理解和利用这一数据类型。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 本文将介绍由密歇根大学Charles Severance教授主讲的顶级Python入门系列课程,该课程广受好评,被誉为Python学习的最佳选择。通过生动有趣的教学方式,帮助初学者轻松掌握编程基础。 ... [详细]
  • 本文介绍如何通过SQL查询从JDE(JD Edwards)系统中提取所有字典数据,涵盖关键表的关联和字段选择。具体包括F0004和F0005系列表的数据提取方法。 ... [详细]
  • 本文介绍如何使用 NSTimer 实现倒计时功能,详细讲解了初始化方法、参数配置以及具体实现步骤。通过示例代码展示如何创建和管理定时器,确保在指定时间间隔内执行特定任务。 ... [详细]
author-avatar
书友74562696
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有