SQL 单表查询.doc
文本预览下载声明
实验三 单表查询
一、实验目的
掌握简单SQL 查询语句的应用,包括like、top、order by、compute 、聚集函数的应用。
二、实验内容
1、基本查询
(1)查询学生表中全体学生的全部信息。
select*
from Student
检索全体学生的学号、姓名。
select Sno,Sname
from Student
2、查询时改变列标题的显示
检索全体学生的学号、姓名、家庭地址信息,并分别加上“学生”、“学号”、“家庭地址”的别名信息。
select Sno学号,Sname姓名,Home_addr家庭地址
from Student
SELECT Sno,Cno,Grade
from SCwhere Grade80;
查询成绩介于75~80分的学生的学号及课程号、成绩。
SELECT Sno,Cno,Grade
from SCwhere Grade between 75 and 80;
查询选修了课程号为“002”,且成绩大于80的学生的学号。
SELECT Sno
from SCwhere Cno=002 AND Grade80;
某些学生选修某门课程后没有参加考试,所以有选课记录,但没有考试成绩,下面我们来查一下缺少成绩的学生的学号和相应的课程号。
SELECT Sno,Cno
from SCwhere Grade IS NULL;
4、基于IN子句的数据查询
从课程表中查询出“高数”、“C语言程序设计”的所有信息。
SELECT*
FROM Coursewhere Cname IN (高数,C语言程序设计);
SELECT Sno,Cno
FROM SCwhere Grade between 70 and 80;
6、基于Like子句的查询
(1)从学生表中分别检索出姓张的所有同学的资料;检索名字的第二个字是“红”或“虹”的所有同学的资料。
SELECT *
FROM Studentwhere Sname LIKE 张%;
SELECT *
FROM Studentwhere Sname LIKE _红%or Sname LIKE_虹%;
SELECT Credit
FROM Coursewhere Cname LIKE visual!_basic escape!;
7、使用top关键字查询
(1)从选课表中检索出前3个课程信息。
SELECT TOP 3*
FROM Course
从选课表中检索出前面20%的课程信息。
SELECT TOP 20 percent*
FROM Course
8、消除重复行
检索出学生已选课程的课程号,要求显示的课程号不重复。
SELECT DISTINCT Cno
FROM SC
9、查询经过计算的值。
查询全体学生的姓名及其年龄(提示:利用系统函数getdate())
select Sname,DATEDIFF(YEAR,Birth,GETDATE()) 年龄
From Student
select * from Studentorder by Classno,Sno
查询全体学生的姓名及其年龄,并按学生的年龄的降序排列。
select Sname,DATEDIFF(YEAR,Birth,GETDATE()) 年龄
from Studentorder by 年龄
select COUNT(Sno) from Student计算“002”号课程的学生平均成绩、最高分、最低分。
select AVG(Grade),MAX(Grade),MIN(Grade)
from SCwhere Cno=002;
12、使用Group子句进行查询
(1)查询各班级学生总人数。
select COUNT(Sno)
from Studentgroup by Classno
汇总总分大于150分的学生的学号及总成绩。
select Sno,SUM(Grade)
from SCgroup by Sno
having SUM(Grade)150;
查询各个课程号相应的选课人数。
select Cno,COUNT(Sno)
from SCgroup by Cno
13、使用Compute和compute by子句进行查询
(1)汇总每个学
显示全部