一、设有一数据库,包括四个表:学生表(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