正确使用SQL Server中的事务

我有2个命令,需要它们都正确执行或没有执行。所以我想我需要一个交易,但我不知道如何正确使用它。

下面的脚本有什么问题?

BEGIN TRANSACTION [Tran1]


INSERT INTO [Test].[dbo].[T1]
([Title], [AVG])
VALUES ('Tidd130', 130), ('Tidd230', 230)


UPDATE [Test].[dbo].[T1]
SET [Title] = N'az2' ,[AVG] = 1
WHERE [dbo].[T1].[Title] = N'az'


COMMIT TRANSACTION [Tran1]
GO

执行了INSERT命令,但是UPDATE命令有问题。

我如何实现这两个命令回滚,如果其中任何一个在执行中有错误?

345310 次浏览

添加一个try/catch块,如果事务成功,它将提交更改,如果事务失败,事务将回滚:

BEGIN TRANSACTION [Tran1]


BEGIN TRY


INSERT INTO [Test].[dbo].[T1] ([Title], [AVG])
VALUES ('Tidd130', 130), ('Tidd230', 230)


UPDATE [Test].[dbo].[T1]
SET [Title] = N'az2' ,[AVG] = 1
WHERE [dbo].[T1].[Title] = N'az'


COMMIT TRANSACTION [Tran1]


END TRY


BEGIN CATCH


ROLLBACK TRANSACTION [Tran1]


END CATCH

在存储过程的开头,应该放置SET XACT_ABORT ON来指示Sql Server在发生错误时自动回滚事务。如果省略或设置为OFF,则需要在每条语句后测试@ error或使用试一试……抓回滚块。

简单的方法:

CREATE TABLE T
(
C [nvarchar](100) NOT NULL UNIQUE,
);


SET XACT_ABORT ON -- Turns on rollback if T-SQL statement raises a run-time error.
SELECT * FROM T; -- Check before.
BEGIN TRAN
INSERT INTO T VALUES ('A');
INSERT INTO T VALUES ('B');
INSERT INTO T VALUES ('B');
INSERT INTO T VALUES ('C');
COMMIT TRAN
SELECT * FROM T; -- Check after.
DELETE T;