• MS SQL入门基础:SQL 流程控制命令


      Transact-SQL 语言使用的流程控制命令与常见的程序设计语言类似主要有以下几种控制命令。

      4.6.1 IF…ELSE

      其语法如下:

      IF <条件表达式>

      <命令行或程序块>

      [ELSE [条件表达式]

      <命令行或程序块>]

      其中<条件表达式>可以是各种表达式的组合,但表达式的值必须是逻辑值“真”或“假”。ELSE子句是可选的,最简单的IF语句没有ELSE子句部分。IF…ELSE用来判断当某一条件成立时执行某段程序,条件不成立时执行另一段程序。如果不使用程序块,IF或ELSE只能执行一条命令。IF…ELSE可以进行嵌套。

      例4-9

      declare@x int,@y int,@z int

      select @x=1,@y=2, @z=3

      if@x>@y

      print'x>y' --打印字符串'x>y'

      else if@y>@z

      print'y>z'

      else print'z>y'

      运行结果如下

      z>y

      注意:在Transact-SQL中最多可嵌套32级。

      4.6.2 BEGIN…END

      其语法如下:

      BEGIN

      <命令行或程序块>

      END

      BEGIN…END用来设定一个程序块,将在BEGIN…END内的所有程序视为一个单元执行BEGIN…END经常在条件语句,如IF…ELSE中使用。在BEGIN…END中可嵌套另外的BEGIN…END来定义另一程序块。

      4.6.3 CASE

      CASE 命令有两种语句格式:

      CASE <运算式>

      WHEN <运算式>THEN<运算式>

      …

      WHEN<运算式>THEN<运算式>

      [ELSE<运算式>]

      END

      CASE

      WHEN <条件表达式> THEN <运算式>

      WHEN <条件表达式> THEN <运算式>

      [ELSE <运算式>]

      END

      CASE命令可以嵌套到SQL命令中。

      例4-10:调整员工工资,工作级别为“1”的上调8%,工作级别为“2”的上调7%,工作级别为“3”的上调6%,其它上调5%。

      use pangu

      update employee

      set e_wage =

      case

      when job_level = ’1’ then e_wage*1.08

      when job_level = ’2’ then e_wage*1.07

      when job_level = ’3’ then e_wage*1.06

      else e_wage*1.05

      end

      注意:执行CASE子句时,只运行第一个匹配的子名。

      4.6.4 WHILE…CONTINUE…BREAK

      其语法如下:

      WHILE <条件表达式>

      BEGIN

      <命令行或程序块>

      [BREAK]

      [CONTINUE]

      [命令行或程序块]

      END

      WHILE 命令在设定的条件成立时会重复执行命令行或程序块。CONTINUE命令可以让程序跳过CONTINUE 命令之后的语句,回到WHILE 循环的第一行命令。BREAK 命令则让程序完全跳出循环,结束WHILE 命令的执行。WHILE 语句也可以嵌套。

      例4-11:

      declare @x int @y int @c int

      例4-11:

      declare @x int, @y int, @c int

      select @x = 1, @y=1

      while @x < 3

      begin

      print @x --打印变量x 的值

      while @y < 3

      begin

      select @c = 100*@ x+ @y

      print @c --打印变量c 的值

      select @y = @y + 1

      end

      select @x = @x + 1

      select @y = 1

      end

      运行结果如下

      1

      101

      102

      2

      201

      202

      4.6.5 WAITFOR

      其语法如下:

      WAITFOR {DELAY <‘时间’> | TIME <‘时间’>

      | ERROREXIT | PROCESSEXIT | MIRROREXIT}

      WAITFOR 命令用来暂时停止程序执行,直到所设定的等待时间已过或所设定的时间已到才继续往下执行。其中‘时间’必须为DATETIME 类型的数据,如:‘11:15:27’,

      但不能包括日期各关键字含义如下:

    DELAY 用来设定等待的时间最多可达24 小时; TIME 用来设定等待结束的时间点; ERROREXIT 直到处理非正常中断; PROCESSEXIT 直到处理正常或非正常中断; MIRROREXIT 直到镜像设备失败。

      例4-12 等待1 小时2 分零3 秒后才执行SELECT 语句

      waitfor delay ’01:02:03’

      select * from employee

    例4-13:等到晚上11 点零8 分后才执行SELECT 语句

      waitfor time ’23:08:00’

      select * from employee

      4.6.6 GOTO

      语法如下:

      GOTO 标识符

      GOTO 命令用来改变程序执行的流程,使程序跳到标有标识符的指定的程序行再继续往下执行。作为跳转目标的标识符可为数字与字符的组合,但必须以“:”结尾,如‘12:’或‘a_1:’。在GOTO 命令行,标识符后不必跟“:”。

      例4-14 分行打印字符‘1’、‘2’、‘3’、‘4’、‘5’

      declare @x int

      select @x = 1

      label_1

      print @x

      select @x = @x + 1

      while @x < 6

      goto label_1

      4.6.7 RETURN

      语法如下

      RETURN [整数值]

      RETURN 命令用于结束当前程序的执行,返回到上一个调用它的程序或其它程序。在括号内可指定一个返回值。

      例4-15

      declare @x int @y int

      select @x = 1 @y = 2

      if x>y

      return 1

      else

      return 2

      如果没有指定返回值,SQL Server 系统会根据程序执行的结果返回一个内定值,如

      表4-5 所示。

      

      如果运行过程产生了多个错误,SQL Server系统将返回绝对值最大的数值;如果此时用户此时定义了返回值,则以返回用户定义的值。RETURN语句不能返回NULL值。

    申明

    非源创博文中的内容均收集自网上,若有侵权之处,请及时联络,我会在第一时间内删除.再次说声抱歉!!!

    博文欢迎转载,但请给出原文连接。

  • 相关阅读:
    重构与反思-<重构代码的7个阶段>有感
    Unity 自定义"=="操作符 [翻译来源blogs.unity3d,2014/05]
    Unity UGUI Button 无法点击问题一例
    [Lua性能] 小试验一例
    C# 循环中 直接索引 VS 缓存索引 性能测试
    Lua table直接索引VS缓存索引性能测试小示例
    大型网站架构系列:负载均衡详解(1)
    大型网站架构系列:电商网站架构案例(3)
    大型网站架构系列:电商网站架构案例(2)
    大型分布式网站架构技术总结
  • 原文地址:https://www.cnblogs.com/Athrun/p/832250.html
Copyright © 2020-2023  润新知