Refigo Blog

<오라클 성능 고도화 원리와 해법2> Ch06-01 테이블 파티셔닝

오라클 성능 고도화 원리와 해법2 - Ch06-01 테이블 파티셔닝 파티셔닝(Partitioning)은 테이블 인덱스 데이터를 파티션(Partition) 단위로 나누어 저장하는 것을 말한다. 테이블을 파티셔닝하면 하나의 테이블일지라도 파티션 키에 따라 물리적으로는 별도의 세그먼트에 데이터가 저장되며, 인덱스도 마찬가지이다. 그림 6-1처럼 계절...

<오라클 성능 고도화 원리와 해법2> Ch05-07 Sort Area 크기 조정

오라클 성능 고도화 원리와 해법2 - Ch05-07 Sort Area 크기 조정 세션 레벨에서 Sort Area 크기를 조정하거나, 시스템 레벨에서 각 세션에 할당될 수 있는 총 크기를 조정해야 할 때가 있다. Sort Area 크기 조정을 통한 튜닝의 핵심은 디스크 소트가 발생하지 않도록 하는 것을 1차 목표로 삼고, 불가피할 때는 Onepass ...

<오라클 성능 고도화 원리와 해법2> Ch05-06 Sort Area를 적게 사용하도록 SQL 작성

오라클 성능 고도화 원리와 해법2 - Ch05-06 Sort Area를 적게 사용하도록 SQL 작성 소트 연산이 불가피하다면 메모리 내에서 처리를 완료할 수 있도록 노력해야 한다. Sort Area 크기를 늘리는 방법도 있지만, 그전에 Sort Area를 적게 사용하는 방법부터 찾는 것이 순서다. (1) 소트를 완료하고 나서 데이터 가공하기 특정...

<오라클 성능 고도화 원리와 해법2> Ch05-05 인덱스를 이용한 소트 연산 대체

오라클 성능 고도화 원리와 해법2 - Ch05-05 인덱스를 이용한 소트 연산 대체 인덱스는 항상 키 컬럼 순으로 정렬된 상태를 유지하므로 이를 이용해 소트 오퍼레이션을 생략할 수 있다. 소트 머지 조인에서 Outer 테이블 조인 컬럼에 인덱스가 있을 때 sort join 오퍼레이션을 생략하는 경우를 2장에서 이미 살펴보았다. 서브쿼리에 사용된 테...

<오라클 성능 고도화 원리와 해법2> Ch05-04 소트가 발생하지 않도록 SQL 작성

오라클 성능 고도화 원리와 해법2 - Ch05-04 소트가 발생하지 않도록 SQL 작성 데이터 모델 측면에서는 이상이 없는데, 불필요한 소트가 발생하도록 SQL을 작성하는 경우가 있다. 예를 들어, 아래처럼 UNION을 사용하면 옵티마이저는 상단과 하단의 두 집합 간 중복을 제거하려고 SORT UNIQUE 연산을 수행한다. 하지만 PK 컬럼인 ...

<오라클 성능 고도화 원리와 해법2> Ch05-03 데이터 모델 측면에서의 검토

오라클 성능 고도화 원리와 해법2 - Ch05-03 데이터 모델 측면에서의 검토 불합리한 데이터 모델이 소트 오퍼레이션을 유발하는 경우를 흔히 접할 수 있다. 튜닝 과정에서 조사된 SQL에 group by, union, distinct 같은 연산자가 불필요하게 많이 사용되는 패턴을 보인다면 대개 데이터 모델이 잘 정규화되지 않았음을 암시한다. 데이터...

<오라클 성능 고도화 원리와 해법2> Ch05-02 소트를 발생시키는 오퍼레이션

오라클 성능 고도화 원리와 해법2 - Ch05-02 소트를 발생시키는 오퍼레이션 (1) Sort Aggregate sort aggregate는 전체로우를 대상으로 집계를 수행할 때 나타나는데, ‘sort’라는 표현을 사용하지만 실제 소트가 발생하지는 않는다. (2) Sort Order By 데이터 정렬을 위해 order by 오퍼레이션을 수...

<오라클 성능 고도화 원리와 해법2> Ch05-01 소트 수행 원리

SQL 튜닝에서 빠질 수 없는 요소가 소트 튜닝이다. 소트 오퍼레이션은 수행 과정에서 CPU와 메모리를 많이 사용하고, 데이터량이 많을 때는 디스크 I/O까지 일으킨다. 많은 서버 리소스를 사용하는 것도 문제지만 부분범위 처리를 불가능하게 해 OLTP 환경에서 애플리케이션 성능을 저하시키는 주요인으로 작용하기도 한다. 오라클 성능 고도화 원리와 해법...

<오라클 성능 고도화 원리와 해법2> Ch04-11 집합 연산을 조인으로 변환

오라클 성능 고도화 원리와 해법2 - Ch04-11 집합 연산을 조인으로 변환 Intersect나 Minus 같은 집합 연산을 조인 형태로 변환하는 것을 말한다. 각각 Sort Unique 연산을 수행한 후에 Minus 연산을 수행하는 것을 볼 수 있다. 해시 Anti 조인을 수행한 후에 중복값을 제거하기 위한 Hash Unique 연산을 수행하...