【发布时间】:2015-12-13 09:48:27
【问题描述】:
当我使用正确的参数运行以下过程以便不返回 -1 值时,我的 DML 语句都不会触发。我猜它把我所有的 DML 语句都当作ELSE 块的一部分。
SQL Server 2014
如何结束 IF-ELSE-ELSE-IF 块?
ALTER PROCEDURE [GenerateNumber] (
@Code VARCHAR(2)
)
AS
BEGIN
DECLARE @stringConcat VARCHAR = 'X';
IF @Code = 'KP'
SET @stringConcat += 'Y';
ELSE IF @Code = 'RL'
SET @stringConcat += 'Z';
ElSE
-- Return error code and stop processing
SELECT -1;
RETURN;
BEGIN TRY
-- Various DML statements...
SELECT @successValue;
RETURN;
END TRY
BEGIN CATCH
SELECT -1;
RETURN;
END CATCH
END
【问题讨论】:
标签: sql-server tsql