Skip to content

Instantly share code, notes, and snippets.

@DaiwenZh5
Last active August 13, 2019 08:40
Show Gist options
  • Save DaiwenZh5/7684cadc988f4c8d9a6e31a0efb25b90 to your computer and use it in GitHub Desktop.
Save DaiwenZh5/7684cadc988f4c8d9a6e31a0efb25b90 to your computer and use it in GitHub Desktop.
Mysql 练习 - part 1
#建学生信息表student
create table student
(
sno varchar(20) not null primary key,
sname varchar(20) not null,
ssex varchar(20) not null,
sbirthday datetime,
class varchar(20)
);
#建立教师表
create table teacher
(
tno varchar(20) not null primary key,
tname varchar(20) not null,
tsex varchar(20) not null,
tbirthday datetime,
prof varchar(20),
depart varchar(20) not null
);
#建立课程表course
create table course
(
cno varchar(20) not null primary key,
cname varchar(20) not null,
tno varchar(20) not null,
foreign key(tno) references teacher(tno)
);
#建立成绩表
create table score
(
sno varchar(20) not null primary key,
foreign key(sno) references student(sno),
cno varchar(20) not null,
foreign key(cno) references course(cno),
degree decimal
);
#添加学生信息
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');
#添加教师表
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','助教','电子工程系');
#添加课程表
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');
#添加成绩表
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('103','3-105','64');
insert into score values('105','3-105','91');
insert into score values('109','3-105','78');
insert into score values('103','6-166','85');
insert into score values('105','6-166','79');
insert into score values('109','6-166','81');

1、 查询 Student 表中的所有记录的 Sname、Ssex 和 Class 列。

SELECT
    Sname,
    Ssex,
    Class
FROM
    Student;

2、查询教师所有的单位即不重复的 Depart 列。

1、查询 Student 表中的所有记录的 Sname、Ssex 和 Class 列。

2、查询教师所有的单位即不重复的 Depart 列。

3、查询 Student 表的所有记录。

4、查询 Score 表中成绩在 60 到 80 之间的所有记录。

5、查询 Score 表中成绩为 85,86 或 88 的记录。

6、查询 Student 表中 “95031” 班或性别为 “女” 的同学记录。

7、以 Class 降序查询 Student 表的所有记录。

8、以 Cno 升序、Degree 降序查询 Score 表的所有记录。

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

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

11、查询每门课的平均成绩。

12、查询 Score 表中至少有 5 名学生选修的并以 3 开头的课程的平均分数。

13、查询分数大于 70,小于 90 的 Sno 列。

14、查询所有学生的 Sname、Cno 和 Degree 列。

15、查询所有学生的 Sno、Cname 和 Degree 列。

16、查询所有学生的 Sname、Cname 和 Degree 列。

17、查询 “95033” 班学生的平均分。

18、假设使用如下命令建立了一个 grade 表:

CREATE TABLE Grade(low INT(3), upp INT(3), rank CHAR(1));
INSERT INTO
    Grade
VALUES(90, 100, 'A');
INSERT INTO
    Grade
VALUES(80, 89, 'B');
INSERT INTO
    Grade
VALUES(70, 79, 'C');
INSERT INTO
    Grade
VALUES(60, 69, 'D');
INSERT INTO
    Grade
VALUES(0, 59, 'E');

现查询所有同学的 Sno、Cno 和 rank 列。

19、查询选修 “3-105” 课程的成绩高于 “109” 号同学成绩的所有同学的记录。

20、查询选了多门课程并且是这个课程下不是最高分的成绩

21、查询成绩高于学号为 “109”、课程号为 “3-105” 的成绩的所有记录。

22、查询和学号为 108、101 的同学同年出生的所有学生的 Sno、Sname 和 Sbirthday 列。

23、查询 “张旭 “教师任课的学生成绩。

24、查询选修某课程的同学人数多于 5 人的教师姓名。

25、查询 95033 班和 95031 班全体学生的记录。

26、查询存在有 85 分以上成绩的课程 Cno.

27、查询出 “计算机系” 教师所教课程的成绩表。

28、查询 “计算 机系” 与 “电子工程系” 不同职称的教师的 Tname 和 Prof。

29、查询选修编号为 “3-105“课程且成绩至少高于选修编号为 “3-245” 的同学的 Cno、Sno 和 Degree, 并按 Degree 从高到低次序排序。

30、查询选修编号为 “3-105” 且成绩高于选修编号为 “3-245” 课程的同学的 Cno、Sno 和 Degree.

31、查询所有教师和同学的 name、sex 和 birthday.

32、查询所有 “女” 教师和 “女” 同学的 name、sex 和 birthday.

33、查询成绩比该课程平均成绩低的同学的成绩表。

34、查询所有任课教师的 Tname 和 Depart.

35、查询所有未讲课的教师的 Tname 和 Depart.

36、查询至少有 2 名男生的班号。

37、查询 Student 表中不姓 “王” 的同学记录。

38、查询 Student 表中每个学生的姓名和年龄。

39、查询 Student 表中最大和最小的 Sbirthday 日期值。

40、以班号和年龄从大到小的顺序查询 Student 表中的全部记录。

41、查询 “男” 教师及其所上的课程。

42、查询最高分同学的 Sno、Cno 和 Degree 列。

43、查询和 “李军” 同性别的所有同学的 Sname.

44、查询和 “李军” 同性别并同班的同学 Sname.

45、查询所有选修 “计算机导论” 课程的 “男” 同学的成绩表。

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment