注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

水滴石穿

破浪是阵风!

 
 
 

日志

 
 

SQL 流程控制命令  

2006-12-05 21:07:42|  分类: 软件开发技术资料 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

SQL 流程控制命令

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

4.6.1 IF…ELSE
其语法如下:
IF <
条件表达式>
<
命令行或程序块>
[ELSE [
条件表达式]
<
命令行或程序块>]
其中<条件表达式>可以是各种表达式的组合,但表达式的值必须是逻辑值ELSE子句是可选的,最简单的IF语句没有ELSE子句部分。IF…ELSE用来判断当某一条件成立时执行某段程序,条件不成立时执行另一段程序。如果不使用程序块,IFELSE只能执行一条命令。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值。

 

  评论这张
 
阅读(109)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017