트랜젝션 롤백(Transaction Rollback)은 데이터베이스 관리 시스템(DBMS)에서 트랜젝션 처리 중 발생한 오류나 불일치가 발생했을 때, 그 이전 상태로 되돌리는 과정을 의미한다. 트랜젝션은 일련의 데이터베이스 작업을 하나의 논리적인 단위로 묶은 것으로, 이러한 작업의 일관성을 보장하기 위해 원자성(Atomicity), 일관성(Consistency), 격리성(Isolation), 지속성(Durability)이라는 ACID 원칙을 따른다.
트랜젝션 롤백은 주로 다음과 같은 상황에서 발생한다. 첫째, 트랜젝션 처리 중 오류가 발생하거나 예외 상황이 발생하여 정상적인 처리 절차를 이어갈 수 없을 때, 둘째, 사용자가 의도적으로 트랜젝션을 취소하거나 롤백 요청을 할 때, 셋째, 트랜젝션이 제한된 시간 내에 완료되지 않아 타임아웃이 발생했을 때 등이 있다.
트랜젝션 롤백을 수행하면, DBMS는 최근의 데이터 변경 사항을 취소하고 해당 트랜젝션이 시작되기 전의 상태로 데이터베이스를 복원한다. 이 과정은 데이터 무결성을 유지하는 데 필수적이며, 데이터가 손실되거나 불일치 상태에 빠지는 것을 방지하는 역할을 한다.
롤백을 수행하는 방법은 대부분의 관계형 데이터베이스에서 지원되며, SQL에서는 `ROLLBACK` 명령어를 사용하여 트랜젝션을 취소할 수 있다. 이 과정에서 데이터베이스는 이전 상태로 돌아가기 위해 로그 파일을 참고하여 필요한 이전 데이터 값을 복원하게 된다.
트랜젝션 롤백은 데이터베이스 시스템의 신뢰성과 안정성을 높이는 데 기여하며, 데이터 관리와 처리에서 중요한 부분으로 자리잡고 있다.