spSellProduct 中,Begin Transaction 和 Commit Transaction 语句被包装在 Begin Try 和 End Try 块之间

如何在 SQL Server 中使用 Try Catch 处理错误?

从 SQL Server 2005 开始,我们在TRY 和 CATCH块的帮助下提供了结构错误处理机制。使用TRY-CATCH的语法如下所示。

BEGIN TRY
--这里写可能导致错误的语句
END TRY
BEGIN CATCH
--当错误发生后,这里的语句将会被执行
END CATCH
-- 其他语句

有可能抛出异常的SQL 语句需要放在BEGIN TRY和END TRY块之间。如果在 TRY 块中发生异常,则控制权立即转移到相应的CATCH块。如果 TRY 块中没有发生异常,则直接跳过CATCH块,执行CATCH块之后的语句。

注意:被 CATCH 捕获的错误不会返回给调用应用程序。如果要将错误信息返回给调用应用程序,则需要将 RAISERROR() 函数显式与 catch 块一起使用。在之前的文章中,我们讨论了如何使用 RAISERROR() 函数显式地引发错误。参考: SQL Server 中的异常处理

示例:了解 SQL Server 中的 Try-Catch 实现。

在下面的示例中,我们使用 SQL Server TRY CATCH 实现和用户定义的错误语句来创建一个用于除以 2 个变量值的存储过程。

IF OBJECT_ID('spDivideTwoNumbers','P') IS NOT NULL
    DROP PROCEDURE spDivideTwoNumbers
GO
CREATE PROCEDURE spDivideTwoNumbers(
@Number1 INT, 
@Number2 INT
)
AS
BEGIN
  DECLARE @Result INT
  SET @Result = 0
  BEGIN TRY
    SET @Result = @Number1 / @Number2
    PRINT '结果是: ' + CAST(@Result AS VARCHAR)
  END TRY
  BEGIN CATCH
    PRINT '第二个数字不能为0'
  END CATCH
END

让我们来测试一下这个存储过程

exec spDivideTwoNumbers 100,1

输出: 结果是: 100

exec spDivideTwoNumbers 100,0

输出: 第二个数字不能为0

当我们用正确的值执行上述存储过程时,程序就不会出现错误。这意味着在执行完 try 块中的所有语句后,控件直接跳转到存在于 catch 块之后的语句,而不执行 catch 块。

如果在执行过程中,即在try块中发生任何错误,那么在这种情况下,从发生错误的行开始,控制权直接跳转到catch块。所以 try 块中的其余语句将不会执行,而 catch 块将执行。

注意:在上面的程序中,当错误发生时,我们会显示一条用户自定义的错误消息“第二个数字不能为0”。然而,我们还可以通过调用函数 Error_Message 来显示原始错误消息。为了测试这个重写catch块内的代码如下

ALTER PROCEDURE spDivideTwoNumbers(
@Number1 INT, 
@Number2 INT
)
AS
BEGIN
  DECLARE @Result INT
  SET @Result = 0
  BEGIN TRY
    SET @Result = @Number1 / @Number2
    PRINT '结果是: ' + CAST(@Result AS VARCHAR)
  END TRY
  BEGIN CATCH
    PRINT ERROR_MESSAGE()
  END CATCH
END

再次执行: exec spDivideTwoNumbers 100,0
输出: 遇到以零作除数错误。

ERROR_MESSAGE 是系统函数, 此函数返回导致 TRY...CATCH 构造的 CATCH 块执行的错误消息文本。

在 SQL Server 中使用 try-catch 的示例

我们将使用下面的 Product 和 ProductSales 表来了解如何使用 RaiseError 和 @ERROR 系统定义函数来处理 SQL Server 中的错误。

http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E6%9E%9C%E6%95%A2%E6%AD%A3%E8%A7%84%E5%8E%85%E8%85%BE%E9%BE%9913O952222I5_1s.htm
http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E6%9E%9C%E6%95%A2%E6%AD%A3%E8%A7%84%E5%8E%85%E8%85%BE%E9%BE%99%E3%80%90%E7%BD%91%E5%9D%80Ny68%C2%B7CC%E3%80%91_1s.htm
http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E6%9E%9C%E6%95%A2%E8%80%81%E8%A1%97%E8%85%BE%E9%BE%9913O952222I5_1s.htm
http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E6%9E%9C%E6%95%A2%E8%80%81%E8%A1%97%E8%85%BE%E9%BE%99%E3%80%90%E7%BD%91%E5%9D%80Ny68%C2%B7CC%E3%80%91_1s.htm
http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E8%85%BE%E9%BE%99%E5%BC%80%E6%88%B713O952222I5_1s.htm
http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E8%85%BE%E9%BE%99%E5%BC%80%E6%88%B7%E3%80%90%E7%BD%91%E5%9D%80Ny68%C2%B7CC%E3%80%91_1s.htm
http://house.china.com.cn/sousuo/%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B0%E5%AE%98%E6%96%B9%E7%BD%91%E7%AB%9913O952222I5_1s.htm
http://house.china.com.cn/sousuo/%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B0%E5%AE%98%E6%96%B9%E7%BD%91%E7%AB%99%E3%80%90%E7%BD%91%E5%9D%80Ny68%C2%B7CC%E3%80%91_1s.htm
http://house.china.com.cn/sousuo/%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B0%E7%BC%85%E7%94%B813O952222I5_1s.htm
http://house.china.com.cn/sousuo/%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B0%E7%BC%85%E7%94%B8%E3%80%90%E7%BD%91%E5%9D%80Ny68%C2%B7CC%E3%80%91_1s.htm
http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B0%E6%80%8E%E4%B9%88%E5%BC%80%E6%88%B713O952222I5_1s.htm
http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B0%E6%80%8E%E4%B9%88%E5%BC%80%E6%88%B7%E3%80%90%E7%BD%91%E5%9D%80Ny68%C2%B7CC%E3%80%91_1s.htm
http://house.china.com.cn/sousuo/%E5%A6%82%E4%BD%95%E6%B3%A8%E5%86%8C%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B013O952222I5_1s.htm
http://house.china.com.cn/sousuo/%E5%A6%82%E4%BD%95%E6%B3%A8%E5%86%8C%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B0%E3%80%90%E7%BD%91%E5%9D%80Ny68%C2%B7CC%E3%80%91_1s.htm
http://house.china.com.cn/sousuo/%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B0%E7%82%B9%E5%87%BB%E5%BC%80%E6%88%B713O952222I5_1s.htm
http://house.china.com.cn/sousuo/%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B0%E7%82%B9%E5%87%BB%E5%BC%80%E6%88%B7%E3%80%90%E7%BD%91%E5%9D%80Ny68%C2%B7CC%E3%80%91_1s.htm
http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E8%85%BE%E9%BE%99%E7%BA%BF%E4%B8%8A%E5%B9%B3%E5%8F%B013O952222I5_1s.htm
http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E8%85%BE%E9%BE%99%E7%BA%BF%E4%B8%8A%E5%B9%B3%E5%8F%B0%E3%80%90%E7%BD%91%E5%9D%80Ny68%C2%B7CC%E3%80%91_1s.htm
http://house.china.com.cn/sousuo/%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B0%E5%9C%B0%E5%9D%8013O952222I5_1s.htm
http://house.china.com.cn/sousuo/%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B0%E5%9C%B0%E5%9D%80%E3%80%90%E7%BD%91%E5%9D%80Ny68%C2%B7CC%E3%80%91_1s.htm
http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E5%8D%8E%E7%BA%B3%E5%9B%BD%E9%99%85%E6%80%8E%E4%B9%88%E5%BC%80%E6%88%B713O952222I5_1s.htm
http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E5%8D%8E%E7%BA%B3%E5%9B%BD%E9%99%85%E6%80%8E%E4%B9%88%E5%BC%80%E6%88%B7%E3%80%90%E7%BD%91%E5%9D%80Ny68%C2%B7CC%E3%80%91_1s.htm
http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E8%80%81%E8%A1%97%E9%BC%8E%E7%9B%9B%E5%9B%BD%E9%99%85%E5%BC%80%E6%88%B713O952222I5_1s.htm
http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E8%80%81%E8%A1%97%E9%BC%8E%E7%9B%9B%E5%9B%BD%E9%99%85%E5%BC%80%E6%88%B7%E3%80%90%E7%BD%91%E5%9D%80Ny68%C2%B7CC%E3%80%91_1s.htm
http://house.china.com.cn/sousuo/%E8%85%BE%E9%BE%99%E6%B3%A8%E5%86%8C%E4%BC%9A%E5%91%9813O952222I5_1s.htm
http://house.china.com.cn/sousuo/%E8%85%BE%E9%BE%99%E6%B3%A8%E5%86%8C%E4%BC%9A%E5%91%98%E3%80%90%E7%BD%91%E5%9D%80Ny68%C2%B7CC%E3%80%91_1s.htm
http://house.china.com.cn/sousuo/%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B0%E5%AE%98%E6%96%B9%E5%BE%AE%E4%BF%A113O952222I5_1s.htm
http://house.china.com.cn/sousuo/%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B0%E5%AE%98%E6%96%B9%E5%BE%AE%E4%BF%A1%E3%80%90%E7%BD%91%E5%9D%80Ny68%C2%B7CC%E3%80%91_1s.htm
http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B0%E6%AD%A3%E8%A7%84%E5%90%9713O952222I5_1s.htm
http://house.china.com.cn/sousuo/%E7%BC%85%E7%94%B8%E8%85%BE%E9%BE%99%E5%B9%B3%E5%8F%B0%E6%AD%A3%E8%A7%84%E5%

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值