SQL Server 存储过程,事务、异常回滚处理机制(Begin try Begin Tran Begin Catch)

异常信息输出

在这里插入图片描述

SQL存储过程
CREATE PROCEDURE SP_Fin_Excu
	@FormID UNIQUEIDENTIFIER
AS
BEGIN
		BEGIN TRY
			BEGIN TRAN cal;
				print '';
			COMMIT TRAN cal;
		END TRY
		BEGIN CATCH
			ROLLBACK TRAN cal;
			--异常信息输出
		SELECT ERROR_NUMBER() AS error_number,ERROR_MESSAGE() AS error_message,ERROR_STATE() AS error_state, ERROR_SEVERITY() AS error_severity;
		END CATCH
END
GO
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 请参考以下SQL Server存储过程示例,它可以带有异常处理和回滚:CREATE PROCEDURE [dbo].[usp_example] AS BEGIN BEGIN TRY BEGIN TRANSACTION -- Your T-SQL Statements Here COMMIT TRANSACTION END TRY BEGIN CATCH IF @@TRANCOUNT > 0 ROLLBACK TRANSACTION END CATCH END ### 回答2: 下面是一个使用SQL Server的带有异常回滚事务存储过程示例,它用于在插入订单和订单明细时保持数据的一致性和完整性。 ``` CREATE PROCEDURE sp_InsertOrder @CustomerID INT, @OrderDate DATE, @ProductID INT, @Quantity INT AS BEGIN SET NOCOUNT ON; BEGIN TRY BEGIN TRANSACTION; -- 插入订单 INSERT INTO Orders (CustomerID, OrderDate) VALUES (@CustomerID, @OrderDate); -- 获取刚刚插入的订单ID DECLARE @OrderID INT = SCOPE_IDENTITY(); -- 插入订单明细 INSERT INTO OrderDetails (OrderID, ProductID, Quantity) VALUES (@OrderID, @ProductID, @Quantity); COMMIT TRANSACTION; -- 提交事务 END TRY BEGIN CATCH IF @@TRANCOUNT > 0 BEGIN ROLLBACK TRANSACTION; -- 回滚事务 END -- 输出错误信息 SELECT ERROR_NUMBER() AS ErrorNumber, ERROR_MESSAGE() AS ErrorMessage, ERROR_PROCEDURE() AS ErrorProcedure, ERROR_LINE() AS ErrorLine; END CATCH; END; ``` 在此存储过程中,我们首先使用`BEGIN TRY`和`BEGIN CATCH`块来捕捉可能发生的异常。若异常发生,则通过`ROLLBACK TRANSACTION`语句将事务回滚到之前的状态。 如果没有异常发生,事务会在`COMMIT TRANSACTION`语句处被提交,确保订单和订单明细同时插入,保持数据的一致性。 在`CATCH`块中,我们还可以输出有关异常的详细信息,如错误代码、错误消息、错误存储过程和错误行号等,以便进行故障排除和错误处理。 要使用此存储过程,只需向其传递正确的参数值即可。例如: ``` EXEC sp_InsertOrder 1, '2021-01-01', 100, 5; ``` 以上示例调用了存储过程`sp_InsertOrder`,将`CustomerID`设为1,`OrderDate`设为2021年1月1日,`ProductID`设为100,`Quantity`设为5。如果没有异常发生,订单和订单明细将被成功插入,否则事务将被回滚并输出异常信息。 ### 回答3: 以下是一个带有异常回滚事务功能的SQL Server存储过程示例: ```sql CREATE PROCEDURE [dbo].[usp_ExampleProc] AS BEGIN SET NOCOUNT ON; SET XACT_ABORT ON; BEGIN TRY BEGIN TRANSACTION; -- 执行多个SQL语句来完成业务逻辑 -- 例如插入数据到表A INSERT INTO [dbo].[TableA] (Column1, Column2) VALUES ('Value1', 'Value2'); -- 例如更新数据表B UPDATE [dbo].[TableB] SET Column1 = 'NewValue' WHERE Column2 = 'OldValue'; -- 事务提交 COMMIT TRANSACTION; END TRY BEGIN CATCH -- 如果发生异常回滚事务 ROLLBACK TRANSACTION; -- 根据需要,可以记录异常信息到日志表或返回自定义错误消息 -- 例如:INSERT INTO [dbo].[ErrorLog] (ErrorMessage, ErrorDateTime) VALUES (ERROR_MESSAGE(), GETDATE()) -- 抛出异常或返回错误消息给调用者 THROW; END CATCH; END ``` 上述存储过程使用 `BEGIN TRANSACTION` 来开启一个事务,在 `TRY` 块内执行需要进行的操作,并在 `CATCH` 块内捕获异常并进行回滚操作。同时,代码中使用 `SET XACT_ABORT ON` 来确保在发生异常时可以自动回滚事务。你可以根据实际需求,在 `TRY` 块中编写需要执行的SQL语句以完成业务逻辑,并根据需要在 `CATCH` 块中记录异常信息或返回自定义错误消息。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

下一秒_待续

如有帮到您,给个赞赏(^.^)

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值