您的位置:首页 > 数据库

Transact-SQL 中使用嵌套 TRY...CATCH

2015-02-27 15:59 393 查看
测试代码:

DECLARE @a INT = 9,
@b INT

BEGIN TRY
BEGIN TRY
SET @a = @a / 0
END TRY

BEGIN CATCH
SET @b = 1
END CATCH

SELECT '内部第1个CATCH:' + Cast(@b AS VARCHAR(20))

BEGIN TRY
SET @a = @a / 0
END TRY

BEGIN CATCH
SET @b = @b + 5
END CATCH

SELECT '内部第2个CATCH:' + Cast(@b AS VARCHAR(20))
END TRY

BEGIN CATCH
SELECT '最外CATCH:' + Cast(@b AS VARCHAR(20))
END CATCH




可以发现,当嵌套TRY...CATCH时,如果里面的TRY...CATCH触发,并不会影响外部的,而且代码也不会停止执行。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: