在SQL Server 2008中正确使用事务

Sae*_*eid 213 sql t-sql database sql-server transactions

我有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
Run Code Online (Sandbox Code Playgroud)

INSERT命令已执行但UPDATE命令有问题.如果其中任何一个命令执行错误,我如何实现它来回滚这两个命令?

Dar*_*ren 476

添加一个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  
Run Code Online (Sandbox Code Playgroud)

  • @PiotrNawrot否,如果事务创建失败,则无需在捕获中回滚它。 (3认同)
  • 如果您想查看错误,请将其包含在捕获中:`SELECT ERROR_MESSAGE() AS ErrorMessage;` (3认同)
  • @KevinLeStarge 或简单的“THROW;”,如果您使用的是 SQL Server >= 2012,如[此处](https://dba.stackexchange.com/a/144814/184793)所述 (2认同)

Nik*_*vić 110

在存储过程开始时,应该将SET XACT_ABORT设置为ON,以指示Sql Server在发生错误时自动回滚事务.如果ommited或设置为OFF,则需要在每个语句后测试@@ ERROR或使用TRY ... CATCH回滚块.

  • 注意 - 对于 XACT_ABORT:OFF 是 T-SQL 语句中的默认设置,而 ON 是触发器中的默认设置 (3认同)
  • 换句话说,除非先设置XACT_ABORT ON,否则事务不是原子的。 (2认同)
  • url有下划线很难看出来,但是`XACT_ABORT`里有下划线 (2认同)
  • @U.Busto 当前交易,是的。 (2认同)

Boh*_*dan 30

简单方法:

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;
Run Code Online (Sandbox Code Playgroud)