SQL连接查询习题

发布时间:2024年01月18日

连接查询

1.不同表之间的连接查询

[题01] 查询每个学生及其选修课程的情况。(注:本查询实际上是涉及 Student 与 SC 两个表的连接操作。这两个表之间的联系是通过公共属性Sno实现)

2.自身连接

[题02] 查询每一门课的间接先修课(即先修课的先修课)。(注:在 Course 表关系中,只有每门课的直接先修课信息,而没有先修课的先修课。要得到这个信息,必须先对一门课找到其先修课,再按此先修课的课程号,查找它的先修课程。这就需要要将 Course 表与其自身连接。为方便连接运算,这里为 Course 表取两个别名分别为 A,B)

3.复合条件查询

[题03] 查询每个学生的学号(Sno)、姓名(Sname)、选修的课程名(Cname)及成绩(Grade)。

嵌套查询

1.带谓词IN的嵌套查询

[题04] 查询与“李伟”在同一个系学习的学生学号(Sno)、姓名(Sname)和系名(Sdept)。

[题05]?查询选修了课程名为“数据结构”的学生学号(Sno)和姓名(Sname)。(注:本查询涉及学号、姓名和课程名(Cname)三个属性。学号和姓名存放在 Student 表中,课程名的存放在Course 表中,但 Student 与 Course 两个表之间没有公共属性,必须通过 SC 表建立它们之间的联系。所以本查询实际上涉及三个关系的连接操作。)

2.带比较运算符的嵌套查询

[题06]?用带有比较运算符的嵌套查询实现:查询与“李伟”在同一个系学习的学生学号(Sno)、姓名(Sname)和系名(Sdept)。(注:由于一个学生只可能在一个系学习,因此子查询的结果是一个值,因此可以用=代替IN)

3.带调词 ANY或ALL 的套查询

[题07]?查询计算机系(CS)的不超过自动化系所有学生的年的学生姓名(Sname)和年龄(Sage)。

4.带谓词 EXISTS 的套查询

[题08]?查询所有选修了编号为“1”课程的学生姓名(Sname)和所在系(Sdept)。

集合查询

?[题09]?查询计算机系(CS)的学生或年龄不大于 20 岁的学生信息。

五、数据更新

1.插入数据

[题10]?将学生陈冬的信息(学号:200215128: 姓名:陈冬:性别:男;所在系:IS:年龄:18 岁)插入到 Student 表中。

[题11]?插入一条选课记录 (200215128’,1)。

[题12]?对每一个系,求学生的平均年龄,并把结果存入表文件 Dept_age 中。Dept_age 表文件属性为: Sdept (系名)、Avg_age (平均年龄)。

2.修改数据

[题13]?将学号为“200215121”的学生年龄改为 22 岁。即要修改满足条件的一个元组的属性值。

[题14]?将所有学生的年龄增加1岁。即要修改多个元组的值。

3.删除数据

[题15]?删除学号为 200215128 的学生记录。

文章来源:https://blog.csdn.net/m0_75110976/article/details/135665783
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。