sql查询练习

先创建三个表,分别为student,course,SC(即学生表,课程表,选课表)

分别输入以下信息:

student表:

course表:

sc表:

---------------------------------------------------------------------

--1.分别查询学生表和学生修课表中的全部数据。
SELECT * FROM student--查询学生表
SELECT * FROM course--查询课程表


--2.查询成绩在70到80分之间的学生的学号、课程号和成绩。
SELECT Sno 学号,Cno 课程号,Grade 成绩
FROM SC
WHERE Grade BETWEEN 70 AND 80

--3.查询C01号课程成绩最高的分数

--降序DESC,升序ASC

--4.查询学生都选修了哪些课程,要求列出课程号。

--5.查询修了C02号课程的所有学生的平均成绩、最高成绩和最低成绩。

--6.统计每门课程的修课人数和考试最高分。

--7.统计每个学生的选课门数,并按选课门数的递增顺序显示结果。

--8.统计选修课的学生总数和考试的平均成绩。

--9.查询选课门数超过2门的学生的平均成绩和选课门数。

select student.Sname,avg(sc.grade),count(sc.cno) from student,sc where student.sno = sc.sno group by student.Sname having count(sc.cno) >2


--10.列出总成绩超过200分的学生,要求列出学号、总成绩。

--11.查询选修了c02号课程的学生的姓名和所在系。

--12.查询成绩80分以上的学生的姓名、课程号和成绩,并按成绩的降序排列结果。

--13.查询计算机系男生修了"数据库基础"的学生的姓名、性别、成绩。

--14.查询哪些学生的年龄相同,要求列出年龄相同的学生的姓名和年龄。

--15.查询哪些课程没有人选,要求列出课程号和课程名。

--16.查询有考试成绩的所有学生的姓名、修课名称及考试成绩

--17.分别查询信息系和计算机系的学生的姓名、性别、修课名称、修课成绩,

--18.用子查询实现如下查询:
--(1)    查询选修了C01号课程的学生的姓名和所在系。

--(2)    查询数学系成绩80分以上的学生的学号、姓名。

--(3)    查询计算机系学生所选的课程名.

 



原文地址:https://www.cnblogs.com/dreamyu/p/6443299.html