博客
关于我
数据库系统第三章作业
阅读量: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/

你可能感兴趣的文章
Nodejs教程09:实现一个带接口请求的简单服务器
查看>>
nodejs服务端实现post请求
查看>>
nodejs框架,原理,组件,核心,跟npm和vue的关系
查看>>
Nodejs概览: 思维导图、核心技术、应用场景
查看>>
nodejs模块——fs模块
查看>>
Nodejs模块、自定义模块、CommonJs的概念和使用
查看>>
nodejs生成多层目录和生成文件的通用方法
查看>>
nodejs端口被占用原因及解决方案
查看>>
Nodejs简介以及Windows上安装Nodejs
查看>>
nodejs系列之express
查看>>
nodejs系列之Koa2
查看>>
Nodejs连接mysql
查看>>
nodejs连接mysql
查看>>
NodeJs连接Oracle数据库
查看>>
nodejs配置express服务器,运行自动打开浏览器
查看>>
NodeMCU教程 http请求获取Json中文乱码解决方案
查看>>
Nodemon 深入解析与使用
查看>>
NodeSession:高效且灵活的Node.js会话管理工具
查看>>
node~ http缓存
查看>>
node不是内部命令时配置node环境变量
查看>>