《数据库原理及应用》实验报告附图.doc_第1页
《数据库原理及应用》实验报告附图.doc_第2页
《数据库原理及应用》实验报告附图.doc_第3页
《数据库原理及应用》实验报告附图.doc_第4页
《数据库原理及应用》实验报告附图.doc_第5页
已阅读5页,还剩7页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

实验报告书课程名称: 数据库原理及应用 实验题目: 实验四 SQL Server 数据查询 班 级: 学 号: 姓 名: 指导教师: 成 绩: 批阅教师: 年 月 日 数据库原理及应用实验报告 - 10 -一、实验目的(1) 掌握使用Transact-SQL的SELECT语句进行基本查询的方法。(2) 掌握使用SELECT语句进行条件查询的方法。(3) 掌握SELECT语句的GROUP BY、ORDER BY以及UNION子句的作用和使用方法。(4) 掌握嵌套查询的方法。(5) 掌握连接查询的操作方法。2、 实验内容及步骤1.启动 SQL Server 管理平台,在对象资源管理器中展开studentsdb数据库文件夹。2在studentsdb数据库中使用SELECT语句进行基本查询。(1)在student_info表中,查询每个学生的学号、姓名、出生日期信息。(2)查询学号为0002 的学生的姓名和家庭住址。(3)找出所有男同学的学号和姓名。3使用SELECT语句进行条件查询(1)在grade表中查找分数在8090范围内的学生的学号和分数。(2)在grade表中查询课程编号为0003的学生的平均分。(3)在grade表中查询学习各门课程的人数。(4)将学生按出生日期由大到小排序。(5)查询所有姓“张”的学生的学号和姓名。4对student_info表,按性别顺序列出学生的学号、姓名、性别、出生日期及家庭住址,性别相同的按学号由小到大排序。5使用GROUP BY查询子句列出各个学生的平均成绩。6使用UNION运算符将student_info表中姓“张”的学生的学号、姓名与curriculum表的课程编号、课程名称返回在一个表中,且列名为u_编号、u_名称,如图8所示。图 联合查询结果集7嵌套查询(1)在student_info表中查找与“刘卫平”性别相同的所有学生的姓名、出生日期。(2)使用IN子查询查找所修课程编号为0002、0005的学生学号、姓名、性别。(3)列出学号为0001的学生的分数比0002号的学生的最低分数高的课程编号和分数。(4)列出学号为0001的学生的分数比学号为0002的学生的最高成绩还要高的课程编号和分数。8连接查询(1)查询分数在8090范围内的学生的学号、姓名、分数。(2)查询学习“C语言程序设计”课程的学生的学号、姓名、分数。(3)查询所有男同学的选课情况,要求列出学号、姓名、课程名称、分数。(4)查询每个学生的所选课程的最高成绩,要求列出学号、姓名、课程编号、分数。(5)查询所有学生的总成绩,要求列出学号、姓名、总成绩,没有选修课程的学生的总成绩为空。提示:使用左外连接。 (6)为grade表添加数据行: 学号0004、课程编号为0006、分数为76。查询所有课程的选修情况,要求列出课程编号、课程名称、选修人数,curriculum表中没有的课程列值为空。提示: 使用右外连接。3、 实验结果1. 启动 SQL Server 管理平台,在对象资源管理器中展开studentsdb数据库文件夹2.在studentsdb数据库中使用SELECT语句进行基本查询。(1)在student_info表中,查询每个学生的学号、姓名、出生日期信息。 (2)查询学号为0002 的学生的姓名和家庭住址。(3)找出所有男同学的学号和姓名。3使用SELECT语句进行条件查询(1)在grade表中查找分数在8090范围内的学生的学号和分数。(2) 在grade表中查询课程编号为0003的学生的平均分。(3) 在grade表中查询学习各门课程的人数。(4) 将学生按出生日期由大到小排序。(5) 查询所有姓“张”的学生的学号和姓名。4 对student_info表,按性别顺序列出学生的学号、姓名、性别、出生日期及家庭住址,性别相同的按学号由小到大排序。 5使用GROUP BY查询子句列出各个学生的平均成绩。 6 使用UNION运算符将student_info表中姓“张”的学生的学号、姓名与curriculum表的课程编号、课程名称返回在一个表中,且列名为u_编号、u_名称,如图8所示。 7嵌套查询(1)在student_info表中查找与“刘卫平”性别相同的所有学生的姓名、出生日期。 Select 姓名,出生日期From student_info Where 性别=男(select 性别 from student_infoWhere 姓名=刘卫平)(2) 使用IN子查询查找所修课程编号为0002、0005的学生学号、姓名、性别。 (3) 列出学号为0001的学生的分数比0002号的学生的最低分数高的课程编号和分数。(4) 列出学号为0001的学生的分数比学号为0002的学生的最高成绩还要高的课程编号和分数。 8连接查询(1)查询分数在8090范围内的学生的学号、姓名、分数。 (2) 查询学习“C语言程序设计”课程的学生的学号、姓名、分数。 (3) 查询所有男同学的选课情况,要求列出学号、姓名、课程名称、分数。 (4) 查询每个学生的所选课程的最高成绩,要求列出学号、姓名、课程编号、分数。 Select student_info.姓名,grade.学号,curriculum.课程编号,grade.分数From (5) 查询所有学生的总成绩,要求列出学号、姓名、总成绩,没有选修课程的学生的总成绩为空。 (6) 为grade表添加数据行: 学号0004、课程编号为0006、分数为76。查询所有课程的选修情况,要求列出课程编号、课程名称、选修人数,curriculum表中没有的课程列值为空。 4、 结果分析1查询所有没有选修课程的学生信息,返回结果包括学号、姓名、性别。SELECT student_id,student_name,student_sexFROM student_infoWHERE (student_id NOT IN (SELECT student_id FROM grade)2 如何实现在student_info表和grade表之间实现交叉连接。 SELECT a.student_id,a.student_name,b.student_id,b.course_no FROM student_info a CROSS JOIN grade b 3 如何实现查询每个学生的所选课程的成绩,并列出学号生成分组汇总行(总成绩)和明细行(各课成绩)。SELECT a.student_id,a.student_name, c.course_name,b. scoreFROM student_info a inner joingrade b ON a.student_id=b.student_id inner join course_info c ON c.course_no= b.course_noORDER BY a.student_idCOMPUTE SUM(score) BY a.student_id4在查询语句中SELECT、FROM和WHERE选项

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论