본문 바로가기

프로그래밍&IT/MySQL, Oracle, DB 공통

데이터 베이스의 옵티마이저 (Database Optimizer)에 대해서

C# (Winfrom) UI만 개발하다보니 데이터베이스에 대해서 좀 소홀히 한 것도 있다.

 

 

데이터베이스의 옵티마이저 (Database Optimizer)

  • SQL 쿼리가 어떻게 효율적으로 실행될지를 결정하는 핵심 요소.
  • 옵티마이저는 데이터베이스가 SQL 쿼리를 실행할 때 가장 적은 자원을 사용하면서 빠르게 결과를 반환할 수 있는 실행 계획을 선택하는 역할
  • SQL 쿼리가 작성된 방식과 데이터베이스의 상태에 따라 크게 영향을 받는다.
  • 옵티마이저는 주로 아래와 같은 방식으로 SQL 쿼리를 최적화하게 된다.

1. 실행 계획 생성

SQL 쿼리가 입력되면 옵티마이저는 여러 실행 계획을 생성하여 가능한 모든 경로를 평가합니다.

이때 각 경로는 인덱스를 사용하거나, 테이블을 스캔하거나, 조인 방식을 결정하는 등의 다양한 전략을 고려합니다.

2. 비용 기반 최적화

많은 데이터베이스 옵티마이저는 비용 기반 최적화를 사용하여 각 실행 계획의 비용을 계산합니다.

* 비용의 종류

1) CPU 비용 (CPU Cost)

  • 정의: 쿼리를 실행하는 동안 CPU 자원을 사용하는 데 필요한 비용입니다.
  • 원인: 계산 집약적인 작업, 큰 데이터셋에 대한 조인 연산, 정렬 및 집계 작업 등.

2) 메모리 비용 (Memory Cost)

  • 정의: 쿼리 실행 시 필요한 메모리 자원에 드는 비용입니다.
  • 원인: 대용량 데이터의 임시 테이블 생성, 복잡한 쿼리의 중간 결과 저장, 해시 조인 등 메모리 집약적인 작업.

3) I/O 비용 (I/O Cost)

  • 정의: 데이터베이스가 디스크에서 데이터를 읽고 쓰는 데 드는 비용입니다.
  • 원인: 인덱스가 없는 테이블의 전체 스캔, 대량의 데이터를 읽고 쓰는 작업, 비효율적인 테이블 조인.

4) 네트워크 비용 (Network Cost)

  • 정의: 분산 시스템이나 클러스터 환경에서 쿼리 실행 시 데이터 전송에 소요되는 비용입니다.
  • 원인: 여러 노드 간 데이터 이동, 복잡한 분산 조인, 원격 서버에서의 데이터 읽기 및 쓰기.

* 비용을 줄이는 방법

1) 쿼리 최적화 (Query Optimization)

  • 방법: SQL 문을 효율적으로 작성하여 불필요한 연산을 줄입니다. 예를 들어, 불필요한 컬럼을 선택하지 않고 필요한 데이터만 쿼리하는 것이 좋습니다.
  • 예시: SELECT * 대신 필요한 컬럼을 지정하거나, 서브쿼리 대신 조인을 사용하는 방법.

2) 인덱스 사용 (Use of Indexes)

  • 방법: 자주 조회되는 컬럼에 인덱스를 생성하면 검색 속도를 크게 개선할 수 있습니다.
  • 주의: 너무 많은 인덱스는 데이터 수정 시 오버헤드를 증가시키므로 필요한 곳에만 적절히 사용하는 것이 좋습니다.

3) 통계 정보 업데이트 (Statistics Update)

  • 방법: 최신 데이터에 맞춰 테이블과 인덱스의 통계 정보를 정기적으로 업데이트하면 옵티마이저가 더 효율적인 실행 계획을 선택할 수 있습니다.
  • 예시: ANALYZE TABLE 또는 UPDATE STATISTICS 명령어를 사용하여 데이터베이스 통계를 최신 상태로 유지.

4) 캐싱 활용 (Use of Caching)

  • 방법: 자주 사용되는 데이터를 캐시하여 디스크 I/O 비용을 줄입니다.
  • 예시: Redis와 같은 메모리 기반 캐시를 사용하거나 데이터베이스의 쿼리 캐시 기능을 활용.

5) 조인 방식 최적화 (Optimize Join Methods)

  • 방법: 옵티마이저가 효율적인 조인 방식(예: 해시 조인, 중첩 루프 조인)을 선택할 수 있도록 데이터를 정규화하고 인덱스를 적용합니다.
  • 주의: 대량의 데이터 조인은 성능에 영향을 미칠 수 있으므로, 필요한 경우 조인을 최소화하거나 서브쿼리를 재구성합니다.

6) 분할과 파티셔닝 (Partitioning)

  • 방법: 큰 테이블을 여러 작은 파티션으로 나누어 데이터를 관리하면 특정 파티션만 읽어도 되므로 I/O 비용을 줄일 수 있습니다.
  • 예시: 시간별로 데이터를 파티셔닝하여, 특정 기간의 데이터만 조회할 수 있도록 구성.

3. 통계 정보 활용

데이터베이스는 테이블, 인덱스, 데이터 분포 등과 관련된 통계 정보를 수집하여 저장합니다. 이 통계 정보를 기반으로 옵티마이저는 SQL 쿼리의 실행 계획을 더욱 정확하게 예측할 수 있습니다.

예를 들어, 통계 정보를 통해 인덱스를 사용할지, 풀 스캔을 할지 결정할 수 있습니다.

4. 힌트(Hint)의 사용

SQL 쿼리 작성 시 힌트를 추가하여 옵티마이저가 특정 방식으로 쿼리를 실행하도록 유도할 수 있습니다.

예를 들어, 특정 인덱스를 사용하거나 특정 조인 방식을 선택하도록 지시할 수 있습니다.

5. SQL 튜닝과의 관계

SQL 튜닝은 SQL 문이 효율적으로 실행되도록 수정하는 과정입니다.

튜닝된 SQL 문은 옵티마이저가 더 좋은 실행 계획을 선택할 수 있게 해 줍니다.

예를 들어, 적절한 인덱스를 추가하거나, 쿼리 구조를 단순화하여 옵티마이저가 더욱 효율적으로 실행 계획을 수립할 수 있게 하는 것입니다.

요약하면, 데이터베이스 옵티마이저는 SQL 쿼리가 효율적으로 수행되도록 최적의 실행 계획을 수립하는 역할을 합니다.

SQL 문이 얼마나 효율적으로 작성되었는지, 통계 정보가 얼마나 최신인지, 그리고 적절한 인덱스가 존재하는지에 따라 옵티마이저의 성능이 크게 영향을 받습니다.