目录
1.使用RETURN
RETURN用来立即退出当前的T-SQL批处理、查询或存储过程,并且不执行它之后的批处理/查询/过程域中的任何代码。RETURN仅退出当前域中执行的代码。如果在存储过程A中调用了存储过程B,并且存储过程B发起一个RETURN,那么存储过程B会立即终止,但是存储过程A还会继续,就好像B已经成功完成。
示例1:使用RETURN来无条件终止一个查询:
USE AdventureWorks
GO
IF NOT EXISTS
(SELECT ProductID FROM Production.Product WHERE Color='Pink')
BEGIN
RETURN
END
--不会再执行
SELECT ProductID
FROM Production.Product
WHERE Color='Pink'
示例2:RETURN支持可选的整数表达式:
RETURN[integer_expression]
这个整数值能用于存储过程和调用应用程序的通信,例如:
USE AdventureWorks
GO
CREATE PROCEDURE #usp_TempProc
AS
SELECT 1/0
RETURN @@ERROR
GO
--执行存储过程,从局部变量捕获RETURN代码
DECLARE @ErrorCode int
EXEC @ErrorCode=#usp_TempProc
PRINT @ErrorCode
示例演示了创建一个临时存储过程,它包含了创建以O作除数的错误的T-SQL。RETURN用