前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >数据库” 查询选修所有课的学生信息“ exists解法的理解

数据库” 查询选修所有课的学生信息“ exists解法的理解

作者头像
老白
发布2018-03-19 16:09:23
1.5K0
发布2018-03-19 16:09:23
举报
文章被收录于专栏:架构之路架构之路

学生选课信息共三个表:

S:学生基本信息

  sno   sname

95001

李二

95002

王三

95003

赵四

95004

孙小毛

95005

王大侃

C:课程基本信息

 cno   cname

1

逻辑与幽默

2

电影艺术欣赏

3

大学生文化之道

4

领导魅力论

SC:选课信息

sno    cno

95001

1

95002

3

95004

4

95005

2

95001

3

95001

2

95001

4

首先得搞懂嵌套查询中相关子查询的执行过程:

 首先选取父查询表中的一个元组,内部的子查询利用此元组中的相关属性值进行查询

然后父查询根据子查询返回的结果判断此行是否满足查询条件,若满足,则把该行放入父查询的查询结果中。

相当于一个循环,逐个的实验。

我们先来看看这个问题

问题一、

查询学号为‘95002’的学生选修的课程信息

select * from C  where exists (select * from SC where SC.cno = C.cno and SC.sno = '95002' );

按照上述的相关子查询的执行过程:

C表中共有课程号为1,2,3,4的四门课,子查询把这四个学号对应的四个元组逐一带入,

根据子查询中的条件SC.cno = C.cno and SC.sno = '95002' 

当C.cno = 1, 不存在符合条件的元组,exists返回false,父查询中不把该C.cno对应的元组放到查询结果中

当C.cno = 2,存在符合条件的元组,exists返回true,父查询中把该C.cno对应的元组放到查询结果中

当C.cno = 3 .......

当C.cno = 4 .........

逐一查询之后,就把C.cno =2 对应的元组选出来了

同理问题二、

查询学号为‘95002’未选修的课程就是

select * from C where not exists (select * from SC where SC.sno = ‘95002’ and SC.cno = C.cno);

好了,接下来我们分析文章开始提出的问题:

select * from S where not exists

                                  (select * from C where not exists  

                                                                (select * from SC where SC.sno = ‘95002’ and SC.cno = C.cno));

还记得我们学过的

            for(i= 0 ;i < 5;i++)

                    for(j = 0; j < 4;j++)

                         某语句;

仿照上述的分析过程S表中学号分别为95001,.....,95005对应的五个元组

 当Sno =95001时,这个问题就又转化为问题二了。学号为95001的学生未选修的课程是否为空,为空的的话保留。

........

遍历完学生信息表中的元组之后,也就把所有符合条件的元组选出来了。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016-04-12 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档