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

第七章Transact-SQL程序设计.pptVIP

  1. 1、本文档共84页,可阅读全部内容。
  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文档。上传文档
查看更多
第七章Transact-SQL程序设计

本章主要内容 7.3 程序控制语句 7.3.3 CASE表达式 2.搜索CASE表达式 【格式】 CASE WHEN 逻辑表达式1 THEN 结果表达式1 [WHEN 逻辑表达式2 THEN 结果表达式2 …… WHEN 逻辑表达式n WHEN 结果表达式n] [ELSE 结果表达式n+1] END 【功能】依次计算WHEN子句后的“逻辑表达式1”、“逻辑表达式2”、……、“逻辑表达式n”,直到找到第一个值为TRUE的“逻辑表达式”,把该WHEN子句后的“结果表达式”作为CASE表达式的值返回。如果所有的“逻辑表达式”的值均为FALSE,则检查是否有ELSE子句存在。如果有ELSE子句,便将ELSE子句之后的“结果表达式”作为CASE表达式值返回;如果不存在ELSE子句,便返回一个NULL值作为CASE表达式的值。 【例7-5】从SelectCourse表中查询出所有学生的选课信息,包括学号、课程名(用课程名代替课号)和成绩(用成绩等级代替成绩,成绩等级为优秀、良好、中等、及格和不及格),并按学号降序排列。 SELECT StuNo,CourseNo= CASE CourseNo WHEN 0001 THEN 计算机应用基础 WHEN 0002 THEN 程序设计基础 WHEN 0003 THEN 操作系统 ELSE 计算机网络技术 END,Score= CASE WHEN Score=90 THEN 优秀 WHEN Score=80 THEN 良好 WHEN Score=70 THEN 中等 WHEN Score=60 THEN 良好 ELSE 不及格 END FROM SelectCourse ORDER BY StuNo DESC 7.3 程序控制语句 7.3.4 WHILE语句 【格式】 WHILE 逻辑表达式 语句 【功能】首先测试“逻辑表达式”的值,如果为TRUE,则执行“语句”(即循环体);然后再测试“逻辑表达式”,如果为TRUE,再执行语句;……;直到某次测试“逻辑表达式”的值时,发现该表达式的值为FALSE时,退出循环,执行WHILE语句后面的语句。 7.3 程序控制语句 7.3.4 WHILE语句 【格式】 WHILE 逻辑表达式 BEGIN 语句块1 …… [CONTINUE] …… 语句块i …… [BREAK] …… 语句块n END 【功能】首先测试“逻辑表达式”的值,如果为TRUE,则执行BEGIN……END语句块(即循环体);然后再测试“逻辑表达式”,如果为TRUE,再执行BEGIN……END语句块;……;直到某次测试“逻辑表达式”的值时,发现该表达式的值为FALSE时,退出循环,执行WHILE语句后面的语句。如果在执行BEGIN……END语句块的过程中,遇到CONTINUE语句可使程序忽略CONTINUE之后的语句,直接跳回到WHILE命令行,重新测试条件,决定是否执行下一次循环。若遇到BREAK语句将提前直接退出循环,跳转到循环之后的语句 。 【例7-6】编写程序输出12+22+32+…+102的值 。 DECLARE @S AS int,@T AS int DECLARE @I AS smallint SET @S=0 SET @I=1 WHILE @I=10 BEGIN SET @T=@I*@I SET @S=@S+@T SET @I=@I+1 END PRINT 和为:+CONVERT(char(6),@S) 【例7-7】编写程序输出1到100之间所有能被3整除的数的和。 DECLARE @S AS int DECLARE @I AS smallint SET @S=0 SET @I=0 WHILE @I100 BEGIN SET @I=@I+1 IF @I % 30 /*如果@I的值不能被3整除*/

文档评论(0)

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

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

1亿VIP精品文档

相关文档