- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
3实验三单表查询
实验三 单表查询
一、实验目的
掌握简单SQL 查询语句的应用,包括like、top、order by、compute 、聚集函数的应用。
二、实验内容
1、基本查询
(1)查询学生表中全体学生的全部信息。
select * from Student
(2)检索全体学生的学号、姓名。
select Sno,Sname
from Student
2、查询时改变列标题的显示
检索全体学生的学号、姓名、家庭地址信息,并分别加上“学生”、“学号”、“家庭地址”的别名信息。
select Sname as 学生,Sno as 学号,Home_addr as 家庭地址
from Student
3、条件查询
(1)查询成绩大于80分的学生的学号及课程号、成绩。
select Sno,Cno,Grade
from SC
where Grade80
(2)查询成绩介于75~80分的学生的学号及课程号、成绩。
select Sno,Cno,Grade
from SC
where Grade between 75 and 80
(3)查询选修了课程号为“002”,且成绩大于80的学生的学号。
select Sno
from SC
where Grade80 and Cno=002
(4)某些学生选修某门课程后没有参加考试,所以有选课记录,但没有考试成绩,下面我们来查一下缺少成绩的学生的学号和相应的课程号。
select Sno,Cno
from SC
where Grade is null
4、基于IN子句的数据查询
从课程表中查询出“高数”、“C语言程序设计”的所有信息。
select * from Course
where Cname in(高数,c语言程序设计)
5、基于BETWEEN。。。。AND子句的数据查询
查询所有成绩在70-80之间的学生选课信息。(between···and为闭区间)
select * from SC
where Grade between 70 and 80
6、基于Like子句的查询
(1)从学生表中分别检索出姓张的所有同学的资料;检索名字的第二个字是“红”或“虹”的所有同学的资料。
select * from Student
where Sname LIKE 张% or Sname LIKE _红% or Sname LIKE _虹%
(2)查询课程名为Visual_Basic的课程的学分。(提示:使用ESCAPE短语)
select Credit from Course
where Cname LIKE Visual\_Basic ESCAPE \
7、使用top关键字查询
(1)从选课表中检索出前3个课程信息。
select Top 3 *
from Course
(2)从选课表中检索出前面20%的课程信息。
select Top 20 PERCENT *
from Course
8、消除重复行
检索出学生已选课程的课程号,要求显示的课程号不重复。
select distinct Cno from Course
9、查询经过计算的值。
查询全体学生的姓名及其年龄(提示:利用系统函数getdate())
select Sname as 姓名,YEAR(getdate())-YEAR(Birth) as 年龄
from Student
10、使用ORDER BY语句对查询的结果进行排序
(1)显示所有学生的基本信息,按班号排列,班号相同则再按学号排列。
select * from Student
Order by Classno,Sno
查询全体学生的姓名及其年龄,并按学生的年龄的降序排列。
select Sname as 姓名,year(getdate())-year(Birth) as 年龄
from Student
Order by 年龄 desc
11、使用聚合函数
(1)查询学生总人数。
select count(distinct Sno) as 学生总人数
from Student
计算“002”号课程的学生平均成绩、最高分、最低分。
select AVG(Grade) as 平均分,MAX(Grade) as 最高分,MIN(Grade) as 最低分
from SC
Where Cno=002
12、使用Group子句进行查询
(1)查询各班级学生总人数。
select Classno as 班级,COUNT(*) as 学生人数
from Student
Group by Classno
汇总总分大于150分的学生的学号及总成绩。
select Sno as 学号,Sum(
文档评论(0)