请结合教材中给定的关系模式,围绕张三选修的课程名称例子,分析使用相关查询和普通子查询查询的编写区别。
时间: 2024-10-24 20:16:28 浏览: 10
sql查询语句练习(解析版) by 荒唐的达达7
4星 · 用户满意度95%
在关系数据库中,查询通常有几种形式,包括简单查询和嵌套查询(即子查询)。这里我们以张三(SNO为张三的具体学号)选修的课程名称为例进行说明。
**相关查询(也叫等值连接查询)**:
假设我们知道张三的学号(例如SNO张三=1001),并且想要获取他所选修的课程名称,我们可以直接通过 `JOIN` 关系来获取:
```sql
SELECT C.CN
FROM Students S
JOIN SC ON S.SNO = 1001 -- 张三的学号
JOIN Courses C ON SC.CNO = C.CNO;
```
这个查询将 `Students`, `SC`, 和 `Courses` 这三个表关联起来,只返回张三选修的课程名称。
**普通子查询(也叫内连接子查询)**:
在这种情况下,可能会先查询出张三所有的选课记录,然后再从中筛选出课程名称:
```sql
SELECT C.CN
FROM (
SELECT * FROM SC
WHERE SNO = 1001 -- 张三的学号
) subquery
JOIN Courses C ON subquery.CNO = C.CNO;
```
这里先通过一个子查询获取到张三的所有选课(子查询结果为一个临时表),然后再从这个临时表中选择对应的课程名称。
**区别**:
1. 相关查询直接在两个或多个表之间建立联系,效率较高,因为它避免了两次查询。而子查询则先执行内部查询,生成中间结果集,再进行外部查询,可能较慢。
2. 相关查询通常简洁明了,易于理解;子查询可能更复杂,特别是当内部查询涉及到复杂的条件时,但是它可以用于处理更复杂的逻辑。
3. 相关查询适用于已知关联字段的情况,而子查询则可以解决未知关联情况,比如在这例中,我们不确定哪些课程是张三选修的,可能需要先通过一个子查询来确定。
阅读全文