六、流程控制命令

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

6.1 IF…ELSE

其语法如下:

    IF <条件表达式>
	<命令行或程序块>
    [ELSE [条件表达式]
	<命令行或程序块>]

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

例6-1

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级。

6.2 BEGIN…END

其语法如下:

    BEGIN
	<命令行或程序块>
    END

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

6.3 CASE

         CASE 命令有两种语句格式:

	 CASE <运算式>
	WHEN <运算式>THEN<运算式>
	……
	WHEN<运算式>THEN<运算式>
	[ELSE<运算式>]END

	 CASE
	WHEN <条件表达式> THEN <运算式>
	WHEN <条件表达式> THEN <运算式>
	[ELSE <运算式>]
	END

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

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子句时,只运行第一个匹配的子名。

6.4 WHILE…CONTINUE…BREAK

其语法如下:

WHILE <条件表达式>
    	 BEGIN
	<命令行或程序块>
	[BREAK]
	[CONTINUE]
	[命令行或程序块]
    END

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

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

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

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 系统会根据程序执行的结果返回一个内定值

其他命令

 DECLARE

语法如下:

    DECLARE {{ @local_variable data_type }
    | { @cursor_variable_name CURSOR }
    | { table_type_definition }
    } [,...n]]


DECLARE 命令用于声明一个或多个局部变量、游标变量或表变量。在用DECLARE命令声明之后,所有的变量都被赋予初值NULL。需要用SELECT 或SET命令来给变量赋值。变量类型可为系统定义的或用户定义的类型,但不能为TEXT、NTEXT、IMAGE类型。CURSOR 指名变量是局部的游标变量





猜你喜欢

转载自blog.csdn.net/uianqian/article/details/8505352
今日推荐