Lock Escalation(락 에스컬레이션) 은 데이터베이스에서 트랜잭션이 획득한 잠금(Lock)의 범위가 증가하여 더 큰 범위를 잠그는 과정을 의미합니다.
즉, 많은 개별 행(row) 잠금을 유지하는 대신, 일정 임계치를 초과하면 테이블 단위 잠금(table-level lock)으로 변경하여 시스템 성능을 최적화합니다.
💡 Oracle에서는 자동 Lock Escalation이 발생하지 않으며, MS SQL Server나 DB2에서는 기본적으로 지원됨.
즉, Oracle은 기본적으로 Row-level Lock을 유지하며, 필요에 따라 수동으로 테이블 잠금을 수행해야 합니다.
Lock Escalation이 필요한 이유는 너무 많은 개별 행을 잠그면 시스템 리소스가 과부하되기 때문입니다.
📌 락 에스컬레이션이 필요한 상황
Oracle은 Lock Escalation을 자동으로 수행하지 않으며, 기본적으로 Row-level Lock을 유지합니다.
대신, 개발자가 직접 Lock을 조정할 수 있는 기능을 제공합니다.
UPDATE employees SET salary = salary * 1.1 WHERE department_id = 10; UPDATE 문을 실행하면 특정 행(Row)만 잠금이 걸림.LOCK TABLE 문을 사용하여 특정 테이블을 전체 잠금할 수 있음.LOCK TABLE employees IN EXCLUSIVE MODE; ALTER TABLE sales MODIFY PARTITION p1 READ ONLY; p1)을 읽기 전용(Read Only)으로 설정하여 잠금 최소화.TM Lock이 발생하며, DML 작업과 충돌 가능.ALTER TABLE)과 DML이 충돌하지 않도록 미리 테이블 잠금 설정 가능.LOCK TABLE employees IN SHARE MODE; Oracle은 Lock Escalation을 자동으로 수행하지 않으므로, 수동으로 조정해야 합니다.
✅ 1) 대량 업데이트 시 BATCH UPDATE 사용
ROWNUM을 활용하여 배치 단위로 나누어 업데이트 가능.UPDATE employees
SET salary = salary * 1.1
WHERE employee_id IN (SELECT employee_id FROM employees WHERE department_id = 10 AND ROWNUM <= 1000); ✅ 2) Index 활용하여 Lock 범위 최소화
WHERE 조건에 INDEX가 존재하면 불필요한 Lock 방지 가능.CREATE INDEX idx_emp_dept ON employees(department_id); ✅ 3) Explicit Table Lock 사용 (필요한 경우)
LOCK TABLE employees IN EXCLUSIVE MODE; ✅ 4) Undo Tablespace 및 Redo Log 최적화
UNDO_RETENTION 값을 조정하여 Undo 데이터를 빠르게 정리.ALTER SYSTEM SET UNDO_RETENTION=900; LOCK TABLE ... 사용).🚀 Lock Escalation은 Oracle에서는 자동 수행되지 않으며, 대신 수동으로 Lock을 조정하여 성능을 최적화하는 것이 중요함!
요양원 선택 전 반드시 확인해야 할 체크리스트를 공개합니다. 공식 평가 자료 조회법, 방문 시 확인…
공공기관 채용 비리의 실태와 피해 지원자의 대응법을 정리했습니다. 채용 비리 신고 방법, 공익신고자 보호제도, 취준생…
주식 손실을 세금 절약에 활용하는 합법적 방법을 공개합니다. 해외주식 손익통산, ISA 계좌 활용, 연금계좌 절세까지…
배달이 예상 시간보다 크게 늦으면 취소·환불을 요청할 수 있습니다. 배달앱별 지연 취소 방법과 잘못 배달됐을…
통신비 절약의 핵심은 요금제 최적화입니다. 내 데이터 사용량 확인법, 알뜰폰 전환 비교, 위약금 없이 요금제…