#101 | 您所在的位置:网站首页 › mysql45道题 › #101 |
转载网络上的MYSQL练习题45道,练习内容和参考答案如下: https://www.cnblogs.com/The-second/p/5979912.html https://blog.csdn.net/ReadyYes/article/details/51192289 练习题的答案都有具体在数据库中进行操作并且截图贴上,确保答案的正确性。若是有多个答案的,也都放上 设有一数据库,包括四个表:学生表(Student)、课程表(Course)、成绩表(Score)以及教师信息表(Teacher)。 四个表的结构分别如表1-1的表(一)~表(四)所示,数据如表1-2的表(一)~表(四)所示。用SQL语句创建四个表并完成相关题目。 表1-1数据库的表结构 表(一)Student (学生表) 属性名 数据类型 可否为空 含 义 Sno varchar (20) 否 学号(主码) Sname varchar (20) 否 学生姓名 Ssex varchar (20) 否 学生性别 Sbirthday datetime 可 学生出生年月 Class varchar (20) 可 学生所在班级 #学生表 CREATE TABLE STUDENT (SNO VARCHAR(3) NOT NULL, SNAME VARCHAR(4) NOT NULL, SSEX VARCHAR(2) NOT NULL, SBIRTHDAY DATETIME, CLASS VARCHAR(5)) ENGINE=MyISAM AUTO_INCREMENT=348 DEFAULT CHARSET=utf8 ;表(二)Course(课程表) 属性名 数据类型 可否为空 含 义 Cno varchar (20) 否 课程号(主码) Cname varchar (20) 否 课程名称 Tno varchar (20) 否 教工编号(外码) #课程表 CREATE TABLE COURSE (CNO VARCHAR(5) NOT NULL, CNAME VARCHAR(10) NOT NULL, TNO VARCHAR(10) NOT NULL) ENGINE=MyISAM AUTO_INCREMENT=348 DEFAULT CHARSET=utf8 ;表(三)Score(成绩表) 属性名 数据类型 可否为空 含 义 Sno varchar (20) 否 学号(外码) Cno varchar (20) 否 课程号(外码) Degree Decimal(4,1) 可 成绩 主码: #成绩表 CREATE TABLE SCORE (SNO VARCHAR(3) NOT NULL, CNO VARCHAR(5) NOT NULL, DEGREE NUMERIC(10, 1) NOT NULL) ENGINE=MyISAM AUTO_INCREMENT=348 DEFAULT CHARSET=utf8 ;表(四)Teacher(教师表) 属性名 数据类型 可否为空 含 义 Tno varchar (20) 否 教工编号(主码) Tname varchar (20) 否 教工姓名 Tsex varchar (20) 否 教工性别 Tbirthday datetime 可 教工出生年月 Prof varchar (20) 可 职称 Depart varchar (20) 否 教工所在部门 #教师表 CREATE TABLE TEACHER (TNO VARCHAR(3) NOT NULL, TNAME VARCHAR(4) NOT NULL, TSEX VARCHAR(2) NOT NULL, TBIRTHDAY DATETIME NOT NULL, PROF VARCHAR(6), DEPART VARCHAR(10) NOT NULL) ENGINE=MyISAM AUTO_INCREMENT=348 DEFAULT CHARSET=utf8 ;表1-2数据库中的数据 表(一)Student Sno Sname Ssex Sbirthday class 108 曾华 男 1977-09-01 95033 105 匡明 男 1975-10-02 95031 107 王丽 女 1976-01-23 95033 101 李军 男 1976-02-20 95033 109 王芳 女 1975-02-10 95031 103 陆君 男 1974-06-03 95031 #添加学生信息 insert into student values('108','曾华','男','1977-09-01','95033'); insert into student values('105','匡明','男','1975-10-02','95031'); insert into student values('107','王丽','女','1976-01-23','95033'); insert into student values('101','李军','男','1976-02-20','95033'); insert into student values('109','王芳','女','1975-02-10','95031'); insert into student values('103','陆君','男','1974-06-03','95031');表(二)Course Cno Cname Tno 3-105 计算机导论 825 3-245 操作系统 804 6-166 数字电路 856 9-888 高等数学 831 #添加课程表 insert into course values('3-105','计算机导论','825'); insert into course values('3-245','操作系统','804'); insert into course values('6-166','数字电路','856'); insert into course values('9-888','高等数学','831');表(三)Score Sno Cno Degree 103 3-245 86 105 3-245 75 109 3-245 68 103 3-105 92 105 3-105 88 109 3-105 76 101 3-105 64 107 3-105 91 108 3-105 78 101 6-166 85 107 6-166 79 108 6-166 81 #添加成绩表 insert into score values('103','3-245','86'); insert into score values('105','3-245','75'); insert into score values('109','3-245','68'); insert into score values('103','3-105','92'); insert into score values('105','3-105','88'); insert into score values('109','3-105','76'); insert into score values('101','3-105','64'); insert into score values('107','3-105','91'); insert into score values('108','3-105','78'); insert into score values('101','6-166','85'); insert into score values('107','6-166','79'); insert into score values('108','6-166','81');表(四)Teacher Tno Tname Tsex Tbirthday Prof Depart 804 李诚 男 1958-12-02 副教授 计算机系 856 张旭 男 1969-03-12 讲师 电子工程系 825 王萍 女 1972-05-05 助教 计算机系 831 刘冰 女 1977-08-14 助教 电子工程系 #添加教师表 insert into teacher values('804','李诚','男','1958-12-02','副教授','计算机系'); insert into teacher values('856','张旭','男','1969-03-12','讲师','电子工程系'); insert into teacher values('825','王萍','女','1972-05-05','助教','计算机系'); insert into teacher values('831','刘冰','女','1977-08-14','助教','电子工程系');练习题目: 1、 查询Student表中的所有记录的Sname、Ssex和Class列 select Sname,Ssex,Class from Student;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; select * from Score where Degree >= 60 and Degree =5; //因为是人数所以可以用count(*)>4代替 //顺序调换可为group by Cno having count(*)>4 and Cno like '3%'; select avg(Degree) from score where Cno like '3%' and Cno in (select Cno from score group by Cno having count(*)>=5) //用in,不用=,是因为可能会有多个13、查询分数大于70,小于90的Sno列 select sno from score where degree>70 and degree |
CopyRight 2018-2019 实验室设备网 版权所有 |