반응형
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
명령은 문제가있다.
실행 중에 오류가있는 경우 두 명령을 롤백하기 위해 어떻게 구현할 수 있습니까?
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
At the beginning of stored procedure one should put SET XACT_ABORT ON to instruct Sql Server to automatically rollback transaction in case of error. If ommited or set to OFF one needs to test @@ERROR after each statement or use TRY ... CATCH rollback block.
Easy approach:
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;
참고URL : https://stackoverflow.com/questions/10153648/correct-use-of-transactions-in-sql-server
반응형
'IT story' 카테고리의 다른 글
요소에 특정 클래스가 없는지 확인하는 방법은 무엇입니까? (0) | 2020.04.30 |
---|---|
Angular 2의 URL에서 쿼리 매개 변수를 얻는 방법은 무엇입니까? (0) | 2020.04.30 |
DbContext.Database.ExecuteSqlCommand 메서드에 매개 변수를 전달하는 방법은 무엇입니까? (0) | 2020.04.30 |
지정된 응용 프로그램 암호화 키가 없습니다 (0) | 2020.04.30 |
Vim에서 분할 창 취소 (0) | 2020.04.30 |