博客
关于我
数据库系统第三章作业
阅读量:598 次
发布时间:2019-03-12

本文共 3064 字,大约阅读时间需要 10 分钟。

数据库系统第三章作业

一、数据定义

我们需要根据要求定义三张表:学生表S、课程表C以及选课表SC。每张表的字段信息如下:

学生表S

字段及规格:

  • S#: 学号(10位字符,主键)
  • Sname: 学生姓名(8位可变长字符串,非空)
  • Sex: 性别(2位字符)
  • Age: 年龄(整数)
  • sdept: 系部(30位可变长字符串)

表结构定义:

CREATE TABLE S (    S# CHAR(10) PRIMARY KEY,    Sname VARCHAR(8) NOT NULL,    Sex CHAR(2),    Age INT,    sdept VARCHAR(30));

课程表C

字段及规格:

  • C#: 课程编号(4位字符,主键)
  • Cname: 课程名称(20位可变长字符串,非空)
  • Teacher: 教师姓名(8位可变长字符串,非空)

表结构定义:

CREATE TABLE C (    C# CHAR(4) PRIMARY KEY,    Cname VARCHAR(20) NOT NULL,    Teacher VARCHAR(8) NOT NULL);

选课表SC

字段及规格:

  • S#: 学号(10位字符,联合主键,外键引用S表)
  • C#: 课程编号(4位字符,联合主键,外键引用C表)
  • Grade: 成绩(整数)

表结构定义:

CREATE TABLE SC (    S# CHAR(10),    C# CHAR(4),    Grade INT,    PRIMARY KEY (S#, C#),    FOREIGN KEY (S#) REFERENCES S(S#),    FOREIGN KEY (C#) REFERENCES C(C#));

二、SELECT 查询

以下是针对上述数据库的SELECT 查询示例:

查询1:检索LIU老师所授课程的课程号和课程名

SELECT C#, Cname FROM C WHERE Teacher = 'LIU';

查询2:检索年龄大于23的男同学的学号和姓名

SELECT S#, Sname FROM S WHERE Sex = '男' AND Age > 23;

查询3:检索学号为S3的学生所学课程的课程名与任课老师

SELECT DISTINCT Cname, Teacher FROM C WHERE C# IN (    SELECT C# FROM SC WHERE S# = 'S3');

查询4:检索至少选修LIU老师所授课程中一门课程的女学生的姓名

SELECT Sname FROM S WHERE Sex = '女' AND S# IN (    SELECT DISTINCT S# FROM SC WHERE C# IN (        SELECT C# FROM C WHERE Teacher = 'LIU'    ));

查询5:检索WANG同学不学课程的课程号

SELECT DISTINCT C# FROM C WHERE C# NOT IN (    SELECT DISTINCT C# FROM SC WHERE S# IN (        SELECT S# FROM S WHERE Sname = 'WANG'    ));

查询6:检索至少选修2门课的学生的学号

SELECT DISTINCT S# FROM SC GROUP BY S# HAVING COUNT(C#) > 2;

查询7:检索全部学生都选修的课程的课程号和课程名

SELECT C#, Cname FROM C WHERE NOT EXISTS (    SELECT * FROM S WHERE NOT EXISTS (        SELECT * FROM SC WHERE S# = S.S# AND C# = C.C#    ));

查询8:检索选修课程包含LIU老师所授全部课程的学生的学号

SELECT DISTINCT S# FROM SC WHERE NOT EXISTS (    SELECT * FROM C WHERE Teacher = 'LIU' AND NOT EXISTS (        SELECT * FROM SC WHERE S# = S.S# AND C# = C.C#    ));

查询9:检索所有姓张的学生

SELECT * FROM S WHERE Sname LIKE '张%';

查询10:查询每个学生的平均成绩

SELECT S#, AVG(Grade) FROM SC GROUP BY S#;

查询11:查询平均成绩大于等于80分的学生的学号和姓名

SELECT S#, Sname FROM S WHERE S# IN (    SELECT S# FROM SC GROUP BY S# HAVING AVG(Grade) >= 80);

查询12:查询平均成绩第一名的学生的学号和姓名

SELECT S#, Sname FROM S WHERE S# IN (    SELECT TOP 1 S# FROM SC GROUP BY S#	ORDER BY AVG(Grade) DESC);

三、创建视图

视图1:选修LIU老师所带课程的学生视图

CREATE VIEW V_LIU (    学号,姓名,性别,课程号,课程名,成绩) AS SELECT S.S#, Sname, Sex, C#, Cname, GradeFROM S, SC, CWHERE S.S#=SC.S# AND SC.C#=C.C# AND Teacher = 'LIU';

视图2:所有男生的视图

CREATE VIEW V_MALE AS SELECT * FROM S WHERE Sex = '男';

视图3:所有学生的选课视图

CREATE VIEW V_LIU (    学号,姓名,性别,课程号,课程名,成绩) AS SELECT S.S#, Sname, Sex, C#, Cname, GradeFROM S, SC, CWHERE S.S#=SC.S# AND SC.C#=C.C#;

视图4:学生平均成绩的视图

CREATE VIEW V_AVG (    学号,姓名,平均成绩) AS SELECT S.S#, Sname, AVG(Grade)FROM S, SCWHERE S.S#=SC.S# GROUP BY S.S#, Sname;

四、数据操纵语言(DML)命令

命令1:把所有学生的年龄增加1岁

UPDATE S SET Age = Age + 1;

命令2:把所有选修LIU老师所带课程的学生成绩置零

UPDATE SC SET Grade = 0 WHERE C# IN (    SELECT C# FROM C WHERE Teacher = 'LIU');

命令3:删除所有女生的选课记录

DELETE FROM SC WHERE S# IN (    SELECT S# FROM S WHERE Sex = '女');

命令4:删除全部的学生记录

DELETE FROM S;

命令5:向学生表S插入一条记录

INSERT INTO S VALUES('1006', '黎明', '男', 20);

转载地址:http://gjgtz.baihongyu.com/

你可能感兴趣的文章
OSPF 四种路由类型:Intra Area、Inter Area、第一、二类外部路由
查看>>
OSPF 学习
查看>>
OSPF 支持的网络类型:广播、NBMA、P2MP和P2P类型
查看>>
OSPF 概念型问题
查看>>
OSPF 的主要目的是什么?
查看>>
OSPF5种报文:Hello报文、DD报文、LSR报文、LSU报文和LSAck报文
查看>>
SQL Server 存储过程分页。
查看>>
OSPFv3:第三版OSPF除了支持IPv6,还有这些强大的特性!
查看>>
OSPF不能发现其他区域路由时,该怎么办?
查看>>
OSPF两个版本:OSPFv3与OSPFv2到底有啥区别?
查看>>
SQL Server 存储过程
查看>>
OSPF在什么情况下会进行Router ID的重新选取?
查看>>
OSPF在大型网络中的应用:高效路由与可扩展性
查看>>
OSPF太难了,这份OSPF综合实验请每位网络工程师查收,周末弯道超车!
查看>>
OSPF技术入门(第三十四课)
查看>>
OSPF技术连载10:OSPF 缺省路由
查看>>
OSPF技术连载11:OSPF 8种 LSA 类型,6000字总结!
查看>>
OSPF技术连载12:OSPF LSA泛洪——维护网络拓扑的关键
查看>>
OSPF技术连载13:OSPF Hello 间隔和 Dead 间隔
查看>>
OSPF技术连载14:OSPF路由器唯一标识符——Router ID
查看>>