- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
6.3 程序控制流语句 6.3.2 选择控制 1. 条件执行语句IF…ELSE 【例6-27】 嵌套IF…ELSE语句的使用。 IF YEAR(getdate())-@成立年份30 PRINT 成立时间超过30年 ELSE IF YEAR(getdate())-@成立年份20 PRINT 成立时间超过20年 ELSE IF YEAR(getdate())-@成立年份10 PRINT 成立时间超过10年 ELSE PRINT 成立时间少于或等于10年 本例在IF…ELSE语句嵌套了另外IF…ELSE语句,只有当外层IF…ELSE的条件不满足时,才会执行内层IF…ELSE语句的条件判断。 6.1 数据与表达 式 6.2 函数 6.3 程序控制流 语句 6.4 游标管理与 应用 6.3 程序控制流语句 6.3.2 选择控制 2. CASE 函数 对于有多个条件分支执行SQL语句的情况,可以使用多个或者多层嵌套的IF…ELSE语句。书写多个或者多层嵌套的IF…ELSE语句不够简洁也易出错,此时可以使用CASE函数来实现多条件分支选择的情况。 CASE函数计算多个条件并为每个条件返回单个值。CASE具有如下两种格式。 (1)简单CASE函数:将某个表达式与一组简单表达式进行比较以确定结果。 CASE input_expression WHEN when_expression THEN result_expression [ …n ] [ELSE else_result_expression ] END 6.1 数据与表达 式 6.2 函数 6.3 程序控制流 语句 6.4 游标管理与 应用 6.3 程序控制流语句 6.3.2 选择控制 2. CASE 函数 (2)CASE搜索函数 CASE计算一组逻辑表达式以确定结果。 CASE WHEN Boolean_expression THEN result_expression [ …n ] [ ELSE else_result_expression ] END 6.1 数据与表达 式 6.2 函数 6.3 程序控制流 语句 6.4 游标管理与 应用 6.3 程序控制流语句 6.3.2 选择控制 2. CASE 函数 【例6-28】使用简单CASE函数将goods表中的商品分类重命名,以使之更易理解。 SELECT 课程编号,课程名称, 课程类别代号= CASE 课程类别 WHEN 必修 THEN 1 WHEN 选修 THEN 2 WHEN 实践 THEN 3 ELSE 0 END FROM 课程 运行结果如图6-9所示。 6.1 数据与表达 式 6.2 函数 6.3 程序控制流 语句 6.4 游标管理与 应用 6.3 程序控制流语句 6.3.2 选择控制 2. CASE 函数 【例6-29】根据“选课”表中的分数,使用CASE搜索函数判断该成绩所属类别。 SELECT 学号,课程编号,评价= CASE WHEN 成绩 IS NULL THEN 没有成绩 WHEN 成绩=90 THEN 优秀 WHEN 成绩 BETWEEN 60 AND 90 THEN 合格 WHEN 成绩60 THEN 不合格 END FROM 选课 程序运行结果如图6-10所示。 6.1 数据与表达 式 6.2 函数 6.3 程序控制流 语句 6.4 游标管理与 应用 6.3 程序控制流语句 6.3.2 选择控制 GOTO语句将允许程序的执行转移到标签处,尾随在GOTO语句之后的Transact-SQL语句被忽略,而从标签继续处理,这增加了程序设计的灵活性。但是,GOTO语句破坏了程序结构化的特点,使程序结构变得复杂而且难以测试。事实上,使用GOTO语句的程序可以用其他语句来代替,所以尽量少使用GOTO语句。 GOTO语句的语法格式如下: GOTO label 其中,label为GOTO语句处理的起点。label必须符合标识符规则。 3. 跳转语句GOTO 6.1 数据与表达 式 6.2 函数 6.3 程序控制流 语句 6.4 游标管理与 应用 6.3 程序控制流语句 6.3.2 选择控制 3. 跳转语句GOTO
您可能关注的文档
- SPSS数据分析实用教程5-比较均值.ppt
- SPSS数据分析实用教程6-非参数.ppt
- SPSS数据分析实用教程7-相关性.ppt
- SPSS数据分析实用教程8-线性回归分析.ppt
- SPSS数据分析实用教程9 方差分析.ppt
- SPSS数据分析实用教程10 聚类分析.ppt
- SPSS数据分析实用教程11 主成分分析.ppt
- SPSS数据分析实用教程12 因子分析.ppt
- SPSS数据分析实用教程13 判别分析.ppt
- SPSS数据分析实用教程14 典型相关分析.ppt
- SQL Server 2008数据库应用技术第7章 存储过程与触发器.ppt
- SQL Server 2008数据库应用技术第8章 事务和锁.ppt
- SQL Server 2008数据库应用技术第9章 SQL Server安全管理.ppt
- SQL Server 2008数据库应用技术第10章 数据库应用系统开发.ppt
- SQL Server 2012 数据库教程第1章 数据库的基本概念.ppt
- SQL Server 2012 数据库教程第2章 数据库创建.ppt
- SQL Server 2012 数据库教程第3章 表的创建和操作.ppt
- SQL Server 2012 数据库教程第4章 数据库的查询、视图.ppt
- SQL Server 2012 数据库教程第5章 T-SQL语言.ppt
- SQL Server 2012 数据库教程第6章 索引和完整性.ppt
文档评论(0)