2024年4月19日发(作者:)

实验三 单表查询

一、实验目的

掌握简单SQL 查询语句的应用,包括like、top、order by、compute 、聚集函数的应

用。

二、实验内容

1、基本查询

(1)查询学生表中全体学生的全部信息。

select*

from Student_20103266;

(2)检索全体学生的学号、姓名。

select Sno,Sname

from Student_20103266;

2、查询时改变列标题的显示

检索全体学生的学号、姓名、家庭地址信息,并分别加上“学生”、“学号”、“家

庭地址”的别名信息。

select Sno'学号',Sname'姓名',Home_addr'家庭地址'

from Student_20103266;

3、条件查询

(1)查询成绩大于80分的学生的学号及课程号、成绩。

SELECT Sno,Cno,Grade

from SC_20103266

where Grade>80;

(2)查询成绩介于75~80分的学生的学号及课程号、成绩。

SELECT Sno,Cno,Grade

from SC_20103266

where Grade between 75 and 80;

(3)查询选修了课程号为“002”,且成绩大于80的学生的学号。

SELECT Sno

from SC_20103266

where Cno='002' AND Grade>80;

(4)某些学生选修某门课程后没有参加考试,所以有选课记录,但没有考试成绩,下

面我们来查一下缺少成绩的学生的学号和相应的课程号。

SELECT Sno,Cno

from SC_20103266

where Grade IS NULL;

4、基于IN子句的数据查询

从课程表中查询出“高数”、“C语言程序设计”的所有信息。

SELECT*

FROM Course_20103266

where Cname IN ('高数','C语言程序设计');

5、基于BETWEEN。。。。AND子句的数据查询

查询所有成绩在70-80之间的学生选课信息。

SELECT Sno,Cno

FROM SC_20103266

where Grade between 70 and 80;

6、基于Like子句的查询

(1)从学生表中分别检索出姓张的所有同学的资料;检索名字的第二个字是“红”或

“虹”的所有同学的资料。

SELECT *

FROM Student_20103266

where Sname LIKE '张%';

SELECT *

FROM Student_20103266

where Sname LIKE '_红%'or Sname LIKE'_虹%';

(2)查询课程名为Visual_Basic的课程的学分。(提示:使用ESCAPE短语)

SELECT Credit

FROM Course_20103266

where Cname LIKE 'visual!_basic' escape'!';

7、使用top关键字查询

(1)从选课表中检索出前3个课程信息。

SELECT TOP 3*

FROM Course_20103266;

(2)从选课表中检索出前面20%的课程信息。

SELECT TOP 20 percent*

FROM Course_20103266;

8、消除重复行

检索出学生已选课程的课程号,要求显示的课程号不重复。

SELECT DISTINCT Cno

FROM SC_20103266;

9、查询经过计算的值。

查询全体学生的姓名及其年龄(提示:利用系统函数getdate())

select Sname,DATEDIFF(YEAR,Birth,GETDATE()) 年龄

From Student_20103266;

10、使用ORDER BY语句对查询的结果进行排序

(1)显示所有学生的基本信息,按班号排列,班号相同则再按学号排列。

select * from Student_20103266

order by Classno,Sno

(2) 查询全体学生的姓名及其年龄,并按学生的年龄的降序排列。

select Sname,DATEDIFF(YEAR,Birth,GETDATE()) 年龄

from Student_20103266

order by 年龄

11、使用聚合函数

(1)查询学生总人数。

select COUNT(Sno) from Student_20103266

(2)计算“002”号课程的学生平均成绩、最高分、最低分。

select AVG(Grade),MAX(Grade),MIN(Grade)

from SC_20103266

where Cno='002';

12、使用Group子句进行查询

(1)查询各班级学生总人数。

select COUNT(Sno)

from Student_20103266

group by Classno

(2)汇总总分大于150分的学生的学号及总成绩。

select Sno,SUM(Grade)

from SC_20103266

group by Sno

having SUM(Grade)>150;

(3)查询各个课程号相应的选课人数。

select Cno,COUNT(Sno)

from SC_20103266

group by Cno

13、使用Compute和compute by子句进行查询

(1)汇总每个学生的学号及总成绩。

select *

from SC_20103266

order by Sno

compute sum(Grade) by Sno

(2)按学号汇总出每个学生的学号及总成绩、最高分、最低分,及所有学生总成绩。

select*

from SC_20103266

order by Sno

compute sum(Grade)

compute sum(Grade),max(Grade),min(Grade) by Sno

观察使用Compute子句和Compute by 子句执行结果有何不同?

COMPUTE BY子句可以在结果集内生成控制中断和小计,得到更详细的或总的记录。

它把数据分成较小的组,然后为每组建立详细记录结果数据集(如SELECT),也可为每组产

生总的记录(如GROUP BY)。在COMPUT BY中,定义BY子句不是必要的。如果没有定义

BY子句,则认为整个表为一个组,并且只有两个结果数据集产生,一个拥有所有的详细记

录,另一个只有一行,即拥有总记录