Utilização correcta das transacções no servidor SQL 2008

tenho 2 comandos e preciso que ambos sejam executados correctamente ou nenhum deles seja executado. Acho que preciso de uma transacção, mas não sei usá-la correctamente.

Qual é o problema com o seguinte guião?

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

o comando insert executado, mas o comando update tem um problema. Como posso implementar isso para reverter ambos os comandos se algum deles tiver um erro na execução?

Author: Darren, 2012-04-14

3 answers

Adicione um bloco de tentativa/ captura, se a transacção for bem sucedida, irá efectuar as alterações, se a transacção falhar a transacção será revertida:

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  
 388
Author: Darren, 2018-08-22 14:29:07

No início do procedimento armazenado, deve-se colocar O XACT_ abortar em para instruir o servidor de Sql a anular automaticamente a transacção em caso de erro. Se for necessário testar @ @ ERROR após cada instrução ou usar tente ... Bloqueio das capturas

 98
Author: Nikola Markovinović, 2017-02-15 17:11:25

Abordagem fácil:

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;
 22
Author: Bohdan, 2015-10-17 02:14:27