|
|
1번째 줄: |
1번째 줄: |
− | '''트랜잭션'''(transaction)이란 "쪼갤 수 없는 업무 처리의 최소 단위"를 말한다. '''거래내역'''이라고도 한다. '트렌젝션'이 아니라 '트랜잭션'이 올바른 표기법이다. 영어로 간략히 '''Tx'''라고 표기하기도 한다. 1초당 처리할 수 있는 트랜잭션의 개수를 [[TPS]]라고 한다.
| + | 마 닥치라 임마 로커스체인이 최고여 |
− | | |
− | == 개념 ==
| |
− | | |
− | 트랜잭션은 은행 [[ATM]]이나 [[데이터베이스]] 등의 시스템에서 사용되는 더 이상 쪼갤 수 없는 업무 처리의 최소 단위이다. 예를 들어, A라는 사람이 B라는 사람에게 1,000원을 지급하고 B가 그 돈을 받은 경우, 이 거래 기록은 더 이상 작게 쪼갤 수가 없는 하나의 트랜잭션을 구성한다. 만약 A는 돈을 지불했으나 B는 돈을 받지 못했다면 그 거래는 성립되지 않는다. 이처럼 A가 돈을 지불하는 행위와 B가 돈을 받는 행위는 별개로 분리될 수 없으며 하나의 거래내역으로 처리되어야 하는 단일 거래이다. 이런 거래의 최소 단위를 트랜잭션이라고 한다. 트랜잭션 처리가 정상적으로 완료된 경우 [[커밋]](commit)을 하고, 오류가 발생할 경우 원래 상태대로 [[롤백]](rollback)을 한다.
| |
− | | |
− | == 조건 ==
| |
− | | |
− | [[데이터베이스]]의 트랜잭션이 안전하게 수행되기 위해서는 ACID 조건을 충족해야 한다. '''ACID'''란 Atomicity, Consistency, Isolation, Durability의 약자로서, 데이터베이스의 트랜잭션이 안전하게 수행되기 위한 4가지 필수적인 성질인 원자성, 일관성, 고립성, 지속성을 말한다.
| |
− | * '''원자성'''(atomicity) : 하나의 트랜잭션은 더 이상 작게 쪼갤 수 없는 최소한의 업무 단위이다.
| |
− | * '''일관성'''(consistency) : 트랜잭션이 완료된 결과값은 일관성 있는 데이터베이스 상태로 유지되어야 한다.
| |
− | * '''고립성'''(isolation) : 트랜잭션을 수행하는 도중에 다른 연산 작업이 끼어들어서는 안 된다.
| |
− | * '''지속성'''(durability) : 성공적으로 수행된 트랜잭션은 영구적으로 반영되어야 한다.
| |
− | | |
− | == 같이 보기 ==
| |
− | * [[데이터베이스]]
| |
− | * [[블록체인]]
| |
− | * [[TPS]]
| |
− | | |
− | [[분류:프로그램]]
| |
− | [[분류:데이터베이스]]
| |