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

本文共 3119 字,大约阅读时间需要 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, Grade
FROM S, SC, C
WHERE 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, Grade
FROM S, SC, C
WHERE S.S#=SC.S# AND SC.C#=C.C#;

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

CREATE VIEW V_AVG (
学号,姓名,平均成绩
) AS SELECT S.S#, Sname, AVG(Grade)
FROM S, SC
WHERE 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单元测试之 API性能测试
查看>>
nodejs图片转换字节保存
查看>>
nodejs在Liunx上的部署生产方式-PM2
查看>>
nodejs基于art-template模板引擎生成
查看>>
nodejs字符与字节之间的转换
查看>>
NodeJs学习笔记001--npm换源
查看>>
NodeJs学习笔记002--npm常用命令详解
查看>>
nodejs学习笔记一——nodejs安装
查看>>
vue3+Element-plus icon图标无法显示的问题(已解决)
查看>>
NodeJS实现跨域的方法( 4种 )
查看>>
nodejs封装http请求
查看>>
nodejs常用组件
查看>>
nodejs开发公众号报错 40164,白名单配置找不到,竟然是这个原因
查看>>
Nodejs异步回调的处理方法总结
查看>>
NodeJS报错 Fatal error: ENOSPC: System limit for number of file watchers reached, watch ‘...path...‘
查看>>
nodejs支持ssi实现include shtml页面
查看>>
Nodejs教程09:实现一个带接口请求的简单服务器
查看>>
nodejs服务端实现post请求
查看>>
nodejs框架,原理,组件,核心,跟npm和vue的关系
查看>>
Nodejs概览: 思维导图、核心技术、应用场景
查看>>