SQL Server'da işlemlerin doğru kullanımı


236

Ben 2 komut var ve her ikisi de doğru yürütülmesi veya hiçbiri yürütülmesi gerekir. Sanırım bir işleme ihtiyacım var, ama bunu nasıl doğru kullanacağımı bilmiyorum.

Aşağıdaki komut dosyasındaki sorun nedir?

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

INSERTKomut yürütüldüğünde, ancak UPDATEkomut bir sorunu vardır.

Herhangi birinde yürütme hatası varsa, her iki komutu geri almak için bunu nasıl uygulayabilirim?

Yanıtlar:


513

Bir try / catch bloğu ekleyin, işlem başarılı olursa değişiklikleri uygular, işlem başarısız olursa işlem geri alınır:

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  

1
Olmamalı BEGIN TRANSACTION [Tran1]yerleştirilemez TRY? Her neyse - çok basit ve zarif bir kod parçası.
Piotr Nawrot

4
@PiotrNawrot Hayır, işlem oluşturma başarısız olursa, yakalamada geri almanıza gerek yoktur.
Monsignor


32

Kolay yaklaşım:

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;
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.