개발공부/개념

[개념 정리] 트랜잭션 (transaction)

이자드 2022. 5. 10. 09:20

정의


시스템에서 사용되는 더 이상 쪼갤 수 없는 업무 처리의 최소 단위이다
트랜잭션은 데이터베이스 서버에 여러 개의 클라이언트가 동시에 액세스 하거나 응용프로그램이 갱신을 처리하는 과정에서 중단될 수 있는 경우 등 데이터 부정합을 방지하고자 할 때 사용한다.
데이터베이스의 상태를 변화시키기 위해서 수행하는 작업의 단위이다

작업의 단위는 질의어 한문장이 아니다
작업의 단위는 많은 질의어 명령문들을 사람이 정하는 기준에 따라 정하는 것을 의미한다


데이터베이스 상태를 변화시키는 것은 무엇일까?
간단하게 질의어(sql)를 이용해 데이터베이스에 접근하는 것을 의미한다



트랜잭션의 특징
원자성
일관성
독립성
지속성


원자성 : 
트랜잭션이 데이터베이스에 모두 반영되던가, 아니면 전혀 반영되지 않아야 한다
트랜잭션은 사람이 설계한 논리적인 작업 단위로서, 일처리는 작업단위 별로 이루어져야 사람이 다루는데 무리가 없다.
즉 하나의 트랜잭션은 한 덩어리로 수행되어야 한다

일관성 : 작업처리 결과가 항상 일관성이 있어야 한다는 것이다
트랜잭션이 진행되는 동안 데이터베이스가 변경 되더라도 업데이트된 데이터베이스로 트랜잭션이 진행되는 것이 아니라
처음에 트랜잭션을 진행하기 위해 참조한 데이터베이스로 진행된다. 이것으로 일관성있는 데이터를 볼 수 있는 것이다

독립성 : 둘 이상의 트랜잭션이 동시에 실행되고 있을 경우 어떤 하나의 트랜잭션이라도, 다른 트랜잭션의 연산에
끼어들 수 없다는 것
하나의 특정 트랜잭션이 완료될때까지, 다른 트랜잭션의 결과를 참조할 수 없다.

지속성 : 트랜잭션이 성공적으로 완료됐을 경우, 결과는 영구적으로 반영되어야 한다

여기서 둘 이상의 트랜잭션이 동시에 실행된다?
데이터베이스를 배워본 사람이라면 하나의 트랜잭션이 실행될때는 해당 트랜잭션 외 다른 어떤 수행도 진행되지 않는 다는 점을 알고 있을 것이다
그럼 여기서 둘 이상의 트랜잭션이 동시에 실행된다는 것은 무엇일까?

이는 병행 트랜잭션이라는 명칭을 가지고 있다 병행트랜잭션에 대해 간단히 이해한 대로 설명하자면 하나의 흐름으로 하나의 트랜잭션을
컨트롤 하는 것은 같으나 lock 이라는 개념을 도입해 트랜잭션을 잠그는 것이다. lock을 사용한다면 해당 트랜잭션에 접근할 수 없게 되고 (독립성 충족)
다른 트랜잭션을 사용할 수 있게 되는 것이다.
더 자세하고 정확한 내용을 알고 싶다면 병행 트랜잭션 으로 구글링 해보길 추천한다.


트랜잭션의 commit, rollback 연산
 Commit이란 하나의 트랜잭션이 성공적으로 끝났고, 데이터베이스가 일관성있는 상태에 있을 때, 하나의 트랜잭션이 끝났다라는 것을 알려주기위해 사용하는 연산이다.

이 연산을 사용하면 수행했던 트랜잭션이 로그에 저장되며, 후에 Rollback 연산을 수행했었던 트랜잭션단위로 하는것을 도와준다

Rollback이란 하나의 트랜잭션 처리가 비정상적으로 종료되어 트랜잭션의 원자성이 깨진경우, 트랜잭션을 처음부터 다시 시작하거나, 트랜잭션의 부분적으로만 연산된 결과를 다시 취소시킨다.


후에 사용자가 트랜잭션 처리된 단위대로 Rollback을 진행할 수도 있다.


트랜잭션의 장점

데이터베이스 완전성을 유지를 확신하게 만들어줌 
데이터베이스에 수행된 쿼리는 일체 남지 않음(원자성 충족)
만약 쿼리 하나가 실패하면, 데이터베이스 시스템은 전체 트랜잭션 또는 실패한 쿼리를 롤백 한다.(원자성 충족)
서로 간섭하지 않아야 한다 (독립성 충족)
데이터의 정합성을 보장하기 위한 기능

http://wiki.hash.kr/index.php/%ED%8A%B8%EB%9E%9C%EC%9E%AD%EC%85%98
https://mommoo.tistory.com/62

'개발공부 > 개념' 카테고리의 다른 글

AOP란  (0) 2022.09.03
[용어정리] 오버헤드(overhead) 란?  (0) 2022.06.24
http request 구조  (0) 2022.05.09
[0317] 디버깅  (0) 2022.03.17
[0315] 공부  (0) 2022.03.15