网站大量收购闲置独家精品文档,联系QQ:2885784924

Transact-SQLSELECT语句数据查询.docVIP

  1. 1、本文档共11页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
1.实验目的 (1)掌握使用Transact-SQL的SELECT语句进行基本查询的方法。 (2)掌握使用SELECT语句进行条件查询的方法。 (3)掌握SELECT语句的GROUP BY、ORDER BY以及UNION子句的作用和使用 方法。 (4)掌握嵌套查询的方法。 (5)掌握连接查询的操作方法。 2.实验内容及步骤 (1)在studentsdb数据库中,使用下列SQL语句将输出什么? ① SELECT COUNT(*) FROM grade 统计表的行数 ② SELECT SUBSTRING(姓名,1,2) FROM student_info 取出student_info表中姓名的一个区间内的所有字符 ③ SELECT UPPER(kelly) 将kelly这个字符串转化成 KELLY ④ SELECT Replicate(kelly,3) 将字符串kelly重复三遍 ⑤ SELECT SQRT(分数) FROM grade WHERE 分数=85 求表中的分数大于等于85的平方根 ⑥ SELECT 2,3,POWER(2,3) 计算2的3次幂 ⑦ SELECT YEAR(GETDATE()),MONTH(GETDATE()),DAY(GETDATE()) 显示年月日 (2)在studentsdb数据库中使用SELECT语句进行基本查询。 ① 在student_info表中,查询每个学生的学号、姓名、出生日期信息。 ② 查询学号为0002 的学生的姓名和家庭住址。 ③ 找出所有男同学的学号和姓名。 (3)使用SELECT语句进行条件查询。 ① 在grade表中查找分数在80~90范围内的学生的学号和分数。 ② 在grade表中查询课程编号为0003的学生的平均分。 ③ 在grade表中查询学习各门课程的人数。 ④ 将学生按出生日期由大到小排序。 ⑤ 查询所有姓“张”的学生的学号和姓名。 (4)对student_info表,按性别顺序列出学生的学号、姓名、性别、出生日期及家庭住址,性别相同的按学号由小到大排序。 (5)使用GROUP BY查询子句列出各个学生的平均成绩。 (6)使用UNION运算符将student_info表中姓“张”的学生的学号、姓名与curriculum 表的课程编号、课程名称返回在一个表中,且列名为u_编号、u_名称,如图1-8所示。 图1-8 联合查询结果集 (7)嵌套查询。 ① 在student_info表中查找与“刘卫平”性别相同的所有学生的姓名、出生日期。 ② 使用IN子查询查找所修课程编号为0002、0005的学生学号、姓名、性别。 ③ 列出学号为0001的学生的分数比0002号的学生的最低分数高的课程编号和分数。 ④ 列出学号为0001的学生的分数比学号为0002的学生的最高成绩还要高的课程编号和分数。 (8)连接查询。 ① 查询分数在80~90范围内的学生的学号、姓名、分数。 ② 查询学习“C语言程序设计”课程的学生的学号、姓名、分数。 ③ 查询所有男同学的选课情况,要求列出学号、姓名、课程名称、分数。 ④ 查询每个学生的所选课程的最高成绩,要求列出学号、姓名、课程编号、分数。 ⑤ 查询所有学生的总成绩,要求列出学号、姓名、总成绩,没有选修课程的学生的总成绩为空。 使用左外连接。 ⑥ 为grade表添加数据行: 学号为0004、课程编号为0006、分数为76。查询所有课程的选修情况,要求列出课程编号、课程名称、选修人数,curriculum表中没有的课程列值为空。 使用右外连接。 3.实验思考 (1)查询所有没有选修课程的学生信息,返回结果包括学号、姓名、性别。 (2)在student_info表和grade表之间实现交叉连接。 (3)查询每个学生的所选课程的成绩,并列出学号生成分组汇总行(总成绩)和明细行(各课成绩)。 提示:使用SELECT语句的COMPUTE选项。 (4)在查询语句中SELECT、FROM和WHERE选项分别实现什么运算? 投影,选择,自然连接 (5)在查询的FROM子句中实现表与表之间的连接有哪几种方式?对应的关键字分 别是什么? 内连接(inner join)外连接(left outer join,right outer join,full outer join)和交叉连接(cross join) 注意:请同学们自行保存相关代码,以备下次实验使用,实验完成后,要及时撰写实验报告。

文档评论(0)

dmz158 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档