T-SQL查询——流程控制语句
和其他高级语言一样,T-SQL中也有用于控制流程的语句。T-SQL中的流程控制语句进一步扩展了T-SQL的力量....使得大部分业务逻辑都可以用在数据库层里面进行。但很多对于T-SQL中的流程控制语句并没有系统的了解
在没有流程控制语句的情况下,T-SQL语句是按照从上到下的顺序逐个执行;
使用流程控制语句可以让开发人员可以基于某些逻辑进行选择性的跳转,实现了类似高级语言的跳转结构
流程控制语句的使用范围和Go关键字
流程控制语句只能在单个批处理段(Batch),用户自定义函数和存储过程中使用。不能跨多个批处理段或者用户自定义函数和存储过程。
一个批处理段是有一个或者多个语句组成的一个批处理,之所以叫批处理是因为所有语句一次性被提交到一个SQL实例。在这个批处理范围内,局部变量时相互可见的。
而想让多个语句分多次提交到SQL实例,则需要使用GO关键字。GO关键字本省并不是一个SQL语句,GO关键字可以看做是一个批处理结束的标示符,当遇到GO关键字时,当前GO之前的语句会作为一个批处理直接传到SQL实例执行。所以不再同一个批处理内局部变量不可见,也不可对批处理的语句使用流程控制语句。
在同一个批处理中局部变量互相可见:
在不同的批处理中局部变量不可见
在不同的批处理中,流程控制语句不能跨批处理:
T-SQL中的8个流程控制语句关键字
在T-SQL中,与流程控制语句相关的关键字有8个
1、begin....end 2、goto... 3、if....else.. 4、return 5、break
6、continue 7、while 8、waitfor
begin...end关键字
begin...end关键字也是流程控制语句需要用到的最基本关键字,用于将多个语句划分成逻辑上的一部分。其实可以直接理解成类似c语言中的花括号(”{}“)
while/break/continue关键字
在T-SQL的流程控制语句中,循环语句只有while循环,并没有传统高级语言中的for和switch循环。while除了被用于流程控制语句的循环之外,还经常被用于游标之中。
while关键字和高级语言中的while几乎完全一样。while循环中可以利用break和continue关键字对循环进行控制。
continue关键字用于结束本次循环。直接开始下一次循环
break关键字用于直接跳出while循环语句。
这里值得注意的是,当while循环嵌套式,continue关键字和break关键字只会作用于他们所处的while循环之内,不会对外部的while循环产生作用。
一个简单的例子如下:从1循环到10,当循环到7时,结束本次循环并继续,当循环到8时,跳出循环
If....else关键字
if...else关键字实现了非此即彼的逻辑。和高级语言中的if..else具有完全一样的使用方法,这里就不再讲述了。
还有要注意的是if经常会和exists关键字相结合来查看数据表中指定的数据是否存在。比如
我想查询员工中没有上级的人,如果有这个人,则输出”XXX is our boss“,如果没有,则输出”there is no infomation about our boss“
declare @loginID varchar(50)
if(existis(select * from Employee where mangerID is null))
begin
select @loginID-Employee.LoginID from Employee
where MangerID is Null
print @loginID+'is our boss'
end
else
begin
print 'There is no infomation about our boss'
end
goto关键字
goto关键字因为能打乱程序的整个流程而在高级语言中臭名昭著。goto关键字的使用非常简单,定义一个跳转标签,只要goto标签名就可以了。如果说一定要使用goto关键字的话,最佳实践是只使用在错误处理上,比如:
if(@@error<>0)
goto ERROR
ERROR:print 'Error Description'
return关键字
return是关键字最简单有效直接无条件告诉服务器跳出某个批处理(Batch),用户自定义函数和存储过程的方式。在同一个批处理中return关键字直接截止当前return所在的批处理(Batch)
简单的rerun概念如下面例子:
在存储过程中,rerun语句后面可以返回数字用于返回执行状态或者错误代码
很多人会把rerun语句和raiserror函数搞混,区别在于raiserror函数会引发错误,并且程序依然会往下执行,
waitfor关键字
waitfor关键字允许指定语句在特定时间或是维持特定时间执行。
推迟等待和在特定时间执行的语法分别是waitfor delay '需要等待的执行时间',waitfor time '需要执行程序的精确时间'
简单的语法例子如下:
waitfor的功能可以实现更为复杂的业务逻辑。比如:
我想开始一项促销活动,在当前时间10小时候开始,为8折,20小时候结束,变为9折