#101 您所在的位置:网站首页 mysql45道题 #101

#101

2023-09-18 01:21| 来源: 网络整理| 查看: 265

转载网络上的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 实验室设备网 版权所有