华中科技大学《数据库技术与应用》实验报告专业班级:学生姓名:学号:实验地点:指导教师:实验日期时间:一、实验项目名称:数据查询二、实验学时:三、实验目的:1.掌握使用Transact-SQL的SELECT语句进行基本查询的方法。
2.掌握使用SELECT语句进行条件查询的方法。
3.掌握嵌套查询的方法。
4.掌握多表查询的方法。
5.掌握SELECT语句的GROUP BY和ORDER BY子句的作业和使用方法。
四、实验工具或环境一台装有SQL sever2008的计算机五、实验内容、步骤、代码和结果:0. 创建studentsdb数据库及其相应表,并录入数据。
在SQL Server管理平台上,点击“新建查询”打开查询编辑器窗口,复制粘贴附件“创建数据库代码”中的代码到查询编辑器窗口,运行即可生成相关数据库和表,并有相应的数据。
1.在studentsdb数据库中,使用下列SQL语句将输出什么?(1)SELECT COUNT(*) FROM grade(2)SELECT SUBSTRING(姓名,1,2) FROM student_info(3)SELECT UPPER('kelly')(4)SELECT Replicate('kelly',3)(5)SELECT SQRT(分数) FROM grade WHERE 分数>=85(6)SELECT 2,3,POWER(2,3) 选做(7)SELECT YEAR(GETDATE()),MONTH(GETDATE()),DAY(GETDATE())2.在studentsdb数据库中使用SELECT语句进行基本查询。
(1)在student_info表中,查询每个学生的学号、姓名、出生日期信息。
(2)查询学号为0002的学生的姓名和家庭住址。
select姓名,家庭住址from student_info where学号='0002'(3)找出所有男同学的学号和姓名。
select姓名,家庭住址from student_info where性别='男'3.使用SELECT语句进行条件查询(1)在grade表中查找分数在80~90分为内的学生的学号和分数。
select学号,分数from grade where分数>='80'and分数<='90'(2)在grade表中查询课程编号为0003的学生的平均分。
select AVG(分数)as平均分from grade where课程编号='0003'(3)在grade表中查询学习各门课程的人数select COUNT(*)from grade(4)将学生按出生日期由大到小排序。
select学号,姓名,出生日期from student_info order by出生日期,学号desc(5)查询所有姓“张”的学生的学号和姓名。
SELECT学号,姓名FROM student_info WHERE姓名LIKE'张%'4.对student_info表,按性别顺序列出学生的学号、姓名、性别、出生日期及家庭住址,性别相同的按学号由小到大排序。
select学号,姓名,性别,出生日期,家庭住址from student_info order by student_info.性别,学号asc5.使用GROUP BY查询子句列出各个学生的平均成绩。
select a.学号,a.姓名,AVG(b.分数)as平均成绩from studentsdb.dbo.student_info a inner joingrade bon a.学号=b.学号group by a.姓名,a.学号6.使用UNION运算符将student_info表中姓“刘”的学生的学号、姓名与姓“张”的学生的学号、姓名返回在一个表中,如图4-1所示。
图 4-1select学号,姓名from studentsdb.dbo.student_info where姓名like'刘%'union allselect学号,姓名from studentsdb.dbo.student_info where姓名like'张%7.嵌套查询(1)在student_info表中查找与“刘卫平”性别相同的所有学生的姓名、出生日期。
select姓名,出生日期from studentsdb.dbo.student_info where性别=(select性别from student_info where姓名='刘卫平')(2)使用IN子查询查找所修课程编号为0002、0005的学生学号、姓名、性别。
select学号,姓名,性别from studentsdb.dbo.student_infowhere学号in(select学号from grade where课程编号='0002'or课程编号='0005')(3)列出学号为0001的学生的分数比0002号的学生的最低分数高的课程编号和分数。
select课程编号,分数from gradewhere学号='0001'and分数>(select MIN(分数)from gradewhere学号='0002')(4)列出学号为0001的学生的分数比0002的学生的最高成绩还要高的课程编号和分数。
select课程编号,分数from gradewhere学号='0001'and分数>(select max(分数)from gradewhere学号='0002')8.多表查询(1)查询分数在80~90范围内的学生的学号、姓名、分数。
SELECT student_info.学号,姓名,分数FROM student_info,gradeWHERE student_info.学号=grade.学号 AND 分数 BETWEEN 80 AND 90(2)查询学习“C语言程序设计”课程的学生的学号、姓名、分数。
SELECT student_info.学号,姓名,分数FROM student_info inner join grade on student_info.学号=grade.学号where课程编号=(select课程编号from curriculum where课程名称='C语言程序设计')(3)查询所有男同学的选课情况,要求列出学号、姓名、课程名称、分数。
SELECT student_info.学号,姓名,curriculum.课程名称,分数FROM student_info,grade,curriculumwhere性别='男'and student_info.学号=grade.学号and curriculum.课程编号=grade.课程编号(4)查询每门课程的最高成绩,要求列出课程编号、分数。
USE studentsdbSELECT DISTINCT student_info.学号,姓名,课程编号,分数FROM grade,student_infoWHERE student_info.学号=grade.学号AND分数=(SELECT MAX(分数)FROM grade WHERE student_info.学号=grade.学号)(5)查询所有学生的总成绩,要求列出学号、姓名、总成绩,没有选修课程的学生的总成绩为空。
提示:使用左外连接。
select student_info.学号,姓名,sum(分数)as总成绩from student_info left outer join grade on student_info.学号=grade.学号group by student_info.学号,姓名(6)为grade表添加数据行:学号0004、课程编号为0006、成绩为76。
查询所有课程的选修情况,要求列出课程编号、课程名称、选修人数,curriculum表中没有的课程列值为空。
提示:使用右外连接。
goinsert studentsdb.dbo.grade(学号,课程编号,分数)values('0004','0006','76');select grade.课程编号,课程名称,count(*)from studentsdb.dbo.curriculumright outer join studentsdb.dbo.grade on grade.课程编号=curriculum.课程编号group by grade.课程编号,课程名称六、实验思考1.查询所有没有选修课程的学生信息,返回结果包括学号、姓名、性别。
select学号,姓名,性别from studentsdb.dbo.student_info where学号not in(select学号from studentsdb.dbo.grade)2.在student_info表和grade表之间实现交叉连接。
select*from studentsdb.dbo.student_info a cross joinstudentsdb.dbo.grade3.查询每个学生的所选课程的成绩,并列出学号生成分组汇总行(总成绩)和明细行(各课成绩)。
select学号,分数from studentsdb.dbo.grade order by学号compute sum(分数)by学号提示:使用SELECT语句的COMPUTE选项。
4.在查询语句中SELECT、FROM和WHERE选项分别实现什么运算?投影,选择,自然连接6.在查询的FROM子句中实现表与表之间的连接有哪几种方式?对应的关键字分别是什么?内连接inner join 外链接left outer right outer交叉链接cross join七、总结及心得体会:选择较之以前很复杂八、对本实验过程及方法、手段的改进建议:教师评语及成绩指导教师签名年月日。