实验三单表查询.docx
《实验三单表查询.docx》由会员分享,可在线阅读,更多相关《实验三单表查询.docx(12页珍藏版)》请在冰豆网上搜索。
实验三单表查询
实验三单表查询
一、实验目的
掌握简单SQL查询语句的应用,包括like、top、orderby、compute、聚集函数的应用。
二、实验内容
1、基本查询
(1)查询学生表中全体学生的全部信息。
(2)
检索全体学生的学号、姓名。
selectSno,Sname
fromStudent;
2、查询时改变列标题的显示
检索全体学生的学号、姓名、家庭地址信息,并分别加上“学生”、“学号”、“家庭地址”的别名信息。
selectSno'学号',Sname'姓名',Home_addr'家庭地址'
fromStudent;
3、条件查询
(1)查询成绩大于80分的学生的学号及课程号、成绩。
SELECTSno,Cno,Grade
fromSC
whereGrade>80;
(2)查询成绩介于75~80分的学生的学号及课程号、成绩。
SELECTSno,Cno,Grade
fromSC
whereGradebetween75and80;
(3)查询选修了课程号为“002”,且成绩大于80的学生的学号。
SELECTSno
fromSC
whereCno='002'ANDGrade>80;
(4)某些学生选修某门课程后没有参加考试,所以有选课记录,但没有考试成绩,下面我们来查一下缺少成绩的学生的学号和相应的课程号。
SELECTSno,Cno
fromSC
whereGradeISNULL;
4、基于IN子句的数据查询
从课程表中查询出“高数”、“C语言程序设计”的所有信息。
SELECT*
FROMCourse
whereCnameIN('高数','C语言程序设计');
5、基于BETWEEN。
。
。
。
AND子句的数据查询
查询所有成绩在70-80之间的学生选课信息。
SELECTSno,Cno
FROMSC
whereGradebetween70and80;
6、基于Like子句的查询
(1)从学生表中分别检索出姓张的所有同学的资料;检索名字的第二个字是“红”或“虹”的所有同学的资料。
SELECT*
FROMStudent
whereSnameLIKE'张%';
SELECT*
FROMStudent
whereSnameLIKE'_红%'orSnameLIKE'_虹%';
(2)查询课程名为Visual_Basic的课程的学分。
(提示:
使用ESCAPE短语)
SELECTCredit
FROMCourse
whereCnameLIKE'visual!
_basic'escape'!
';
7、使用top关键字查询
(1)从选课表中检索出前3个课程信息。
SELECTTOP3*
FROMCourse;
(2)从选课表中检索出前面20%的课程信息。
SELECTTOP20percent*
FROMCourse;
8、消除重复行
检索出学生已选课程的课程号,要求显示的课程号不重复。
SELECTDISTINCTCno
FROMSC;
9、查询经过计算的值。
查询全体学生的姓名及其年龄(提示:
利用系统函数getdate())
selectSname,DATEDIFF(YEAR,Birth,GETDATE())年龄
FromStudent;
10、使用ORDERBY语句对查询的结果进行排序
(1)显示所有学生的基本信息,按班号排列,班号相同则再按学号排列。
select*fromStudent
orderbyClassno,Sno
(2)查询全体学生的姓名及其年龄,并按学生的年龄的降序排列。
selectSname,DATEDIFF(YEAR,Birth,GETDATE())年龄
fromStudent
orderby年龄
11、使用聚合函数
(1)查询学生总人数。
selectCOUNT(Sno)总人数
fromStudent
(2)计算“002”号课程的学生平均成绩、最高分、最低分。
selectAVG(Grade)平均数,MAX(Grade)最大数,MIN(Grade)最小数
fromSC
whereCno='002';
12、使用Group子句进行查询
(1)查询各班级学生总人数。
selectCOUNT(Sno)总人数
fromStudent
groupbyClassno
(2)汇总总分大于150分的学生的学号及总成绩。
selectSno,SUM(Grade)总分
fromSC
groupbySno
havingSUM(Grade)>150;
(3)查询各个课程号相应的选课人数。
selectCno,COUNT(Sno)选课人数
fromSC
groupbyCno
13、使用Compute和computeby子句进行查询
(1)汇总每个学生的学号及总成绩。
select*
fromSC
orderbySno
computesum(Grade)bySno
(2)按学号汇总出每个学生的学号及总成绩、最高分、最低分,及所有学生总成绩。
select*
fromSC
orderbySno
computesum(Grade)
computesum(Grade),max(Grade),min(Grade)bySno