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’,
但不能包括日期各關鍵字含義如下:
例4-12 等待1 小時2 分零3 秒后才執行select 語句
waitfor delay ’01:02:03’
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值。
新聞熱點
疑難解答