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

你可能感兴趣的文章
NetApp凭借领先的混合云数据与服务把握数字化转型机遇
查看>>
NetBeans IDE8.0需要JDK1.7及以上版本
查看>>
netcat的端口转发功能的实现
查看>>
netfilter应用场景
查看>>
netlink2.6.32内核实现源码
查看>>
Netpas:不一样的SD-WAN+ 保障网络通讯品质
查看>>
NetScaler的常用配置
查看>>
netsh advfirewall
查看>>
NETSH WINSOCK RESET这条命令的含义和作用?
查看>>
Netty WebSocket客户端
查看>>
netty 主要组件+黏包半包+rpc框架+源码透析
查看>>
Netty 异步任务调度与异步线程池
查看>>
Netty中集成Protobuf实现Java对象数据传递
查看>>
Netty事件注册机制深入解析
查看>>
Netty原理分析及实战(四)-客户端与服务端双向通信
查看>>
Netty客户端断线重连实现及问题思考
查看>>
Netty工作笔记0006---NIO的Buffer说明
查看>>
Netty工作笔记0007---NIO的三大核心组件关系
查看>>
Netty工作笔记0011---Channel应用案例2
查看>>
Netty工作笔记0013---Channel应用案例4Copy图片
查看>>