강의

멘토링

로드맵

개foot님의 프로필 이미지
개foot

작성한 질문수

실무에서 바로 쓰는 SQL튜닝 45가지

튜닝예제4. where 절에 인덱스 컬럼을 가공하지 마세요

날짜 인덱스관련 질문

작성

·

5

0

제가 보통 실무때도 날짜 타입을 흠 귀찮아서??? to_char(날짜타입,'YYYY') = '2025'(예시)

이런식으로하는데 이렇게 하더라도 그럼 실행계획이 무너지겠네요?

 

퀴즈

63%나 틀려요. 한번 도전해보세요!

SQL 인덱스의 주된 목적은 무엇일까요?

데이터 삽입 속도 향상

테이블 구조 변경 방지

데이터 검색 속도 향상

저장 공간 절약

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. 개foot님.

날짜 타입 데이터를 TO_CHAR 함수를 사용하여 문자열로 변환한 후 검색하는 방식에 대해 질문을 주셨군요. 이 방법은 인덱스 사용에 영향을 줄 수 있는데, 아래 설명을 참고하시기 바랍니다.

  1. 함수로 래핑된 컬럼: TO_CHAR와 같은 함수를 사용하면, 기본적으로 해당 컬럼에 대한 인덱스가 작동하지 않게 됩니다. 이를 함수 기반 인덱스(function-based index)를 사용하여 해결할 수 있습니다. 일반적으로 함수가 사용되면 옵티마이저는 해당 컬럼에서 인덱스를 사용할 수 없다고 판단하게 되어, 실행 계획에서 전체 테이블 스캔(full table scan)이 이루어질 가능성이 높아집니다.

  2. 실행 계획: 인덱스를 사용할 수 없게 되면, 쿼리의 성능은 데이터 양에 따라 크게 차이가 날 수 있습니다. 특히 큰 데이터셋에서는 검색 속도가 느려질 수 있습니다. 실행 계획을 확인하여 쿼리가 효율적으로 작동하는지를 판단하고, 필요하다면 인덱스 적용이나 다른 최적화 방법을 고려해 보셔야 합니다.

  3. 추천 방안: 함수 기반 인덱스를 생성하여 TO_CHAR와 같은 함수 이용을 최적화하거나, 날짜 범위를 직접 비교하는 방식을 통해 인덱스를 사용할 수 있도록 설계하시면 성능 개선에 도움이 될 것입니다.

유사한 케이스와 최적화 팁에 대한 추가 정보를 원하시면 아래 링크를 참고해 보세요:

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

개foot님의 프로필 이미지
개foot

작성한 질문수

질문하기