学生选课数据库SQL语句练习题(附详细分解答案)

2019-08-31 20:12

一、设有一数据库,包括四个表:学生表(Student)、课程表(Course)、成绩表(Score)以及教师信息表(Teacher)。四个表的结构分别如表1-1的表(一)~表(四)所示,数据如表1-2的表(一)~表(四)所示。用SQL语句创建四个表并完成相关题目。

表1-1数据库的表结构

表(一)Student 属性名 Sno 数据类可否为型 空 Char(3) 否 含义 学号(主键) 学生姓名 学生性别 学生出生年月 学生所在班级 Sname Char(8) 否 Ssex Char(2) 否 Sbirthday datetime 可 Class Char(5) 可 表(二)Course 属性名 数据类型 可否为含义 空 Cno Char(5) 否 课程号(主键) Cname Varchar(10) 否 课程名称 Tno Char(3) 否 教师编号(外键) 表(三)Score 属性名 数据类型 Sno Cno 数据库

Char(3) Char(5) 可否为空 否 否 含义 学号(外键) 课程号(外wzm

Degree Decimal(4,1) 可 主码:Sno+ Cno 表(四)Teacher 属性名 Tno 数据类型 Char(3) 可否为空 否 否 否 可 键) 成绩 含义 教师编号(主键) 教师姓名 教师性别 教师出生年月 职称 教师所在部门 Tname Char(4) Tsex Char(2) Tbirthday datetime Prof Depart Char(6) 可 Varchar(10) 否 表1-2数据库中的数据 表(一)Student

Sno Sname Ssex Sbirthday class 108 曾华 男 1977-09-95033 01 105 匡明 男 1975-10-95031 02 107 王丽 女 1976-01-95033 23 101 李军 男 1976-02-95033 20 109 王芳 女 1975-02-95031 10 103 陆君 男 1974-06-95031 03

表(二)Course

数据库 wzm

Cno Cname 3-105 计算机导论 3-245 操作系统 6-166 数字电路 9-888 高等数学 Tno 825 804 856 831 表(三)Score Sno 103 105 109 103 105 109 101 107 108 101 107 108 Cno 3-245 3-245 3-245 3-105 3-105 3-105 3-105 3-105 3-105 6-166 6-166 6-166 Degree 86 75 68 92 88 76 64 91 78 85 79 81 表(四)Teacher

Tno Tname Tsex Tbirthday Prof 804 李诚 男 1958-12-副教02 授 856 张旭 男 1969-03-讲师 12 825 831 王萍 刘冰 女 女 1972-05-05 1977-08-14 Depart 计算机系 电子工程系 助教 计算机系 助教 电子工程系 -- 1、查询Student表中的所有记录的Sname、Ssex和Class列。 select sname,ssex,class from student;

数据库

wzm

-- 2、查询教师所有的单位即不重复的Depart列。 select distinct depart from Teacher;

-- 3、查询Student表的所有记录。 select * from student;

-- 4、查询Score表中成绩在60到80之间的所有记录。 select * from score where degree between 60 and 80;

-- 5、查询Score表中成绩为85,86或88的记录。 select * from score where degree in(85,86,88);

-- 6、查询Student表中“95031”班或性别为“女”的同学记录。 select * from student where class = '95031' or ssex='女';

-- 7、以Class降序查询Student表的所有记录。 select * from student order by class desc;

-- 8、以Cno升序、Degree降序查询Score表的所有记录。 select * from score order by cno,degree desc;

数据库 wzm

-- 9、查询“95031”班的学生人数。

select class,count(*) as 学生人数 from student group by class having class='95031';

-- 10、查询Score表中的最高分的学生学号和课程号。(子查询或者排序) select sno,cno,degree,

(select max(degree) from score) as maxscore--计算最高分 from score where degree= (select max(degree) from score);

-- 11、查询?3-105?号课程的平均分。 select avg(degree) as avgdegree

from score group by cno having cno='3-105';

-- 12、查询Score表中至少有5名学生选修的并以3开头的课程的平均分数。 select avg(degree) as avgdegree from score group by cno --按照课程分组取平均值 having cno= (select cno from score group by cno having count(*)>=5)--至少有5名学生选修的课程 and cno like '3%';--以3开头的课程

-- 13、查询最低分大于70,最高分小于90的Sno列。

数据库 wzm


学生选课数据库SQL语句练习题(附详细分解答案).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:聚丙烯腈纤维混凝土技术总结 - 图文

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: