inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

중고급 SQL과 실전 데이터 분석 101 문제 풀이

연습문제로 빠르게 익히는 문자열 관련 SQL 함수 정리

where 컬럼에 함수를 적용하는건 좋지 못하다고 들었습니다.

79

트릴

작성한 질문수 41

0

강의 연습문제 where 컬럼에 함수를 래핑해서 조건을 만족하는 문제를 보았는데요, 테이블 행수가 적을 땐 문제가 안된다고 들었는데, 행 수가 많을때는 컬럼에 함수를 래핑하면 인덱스 적용 불가 및 모든 컬럼에 함수를 적용해야해서 성능이 안좋아진다고 들었는데, 선생님의 의견 궁금합니다.

sql mysql dbms/rdbms

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 트릴님께서 질문하신 내용은 SQL 최적화 관점에서의 중요한 부분입니다.

WHERE 절에서 컬럼에 함수를 적용하는 경우, 인덱스가 제대로 활용되지 않아 성능이 저하될 수 있다는 점은 많은 개발자들이 강조하는 부분입니다. 이는 각 행의 컬럼 값에 대해 함수가 매번 평가되어야 하므로, 인덱스를 통한 빠른 탐색 대신 모든 행을 탐색해야 하기 때문입니다. 이로 인해 데이터 양이 많아질수록 성능이 악화될 수 있습니다.

그러나 행의 수가 적고 제한적인 데이터셋이라면 성능 저하가 눈에 띄지 않을 수 있으며, 이 경우에는 함수를 사용해도 큰 문제는 없습니다. 그러나 실무에서는 데이터의 양이 늘어날 수 있기 때문에, 항상 성능을 염두에 두고 설계를 해야 합니다. 이를 해결하기 위해:
- 가능한 함수 적용을 줄이거나, 필요한 경우 다른 방식으로 대체할 수 있는지를 고려합니다.
- 함수 적용이 필요한 컬럼에 대해 계산된 값을 저장한 새로운 컬럼을 추가하여 사전 계산된 값을 활용하는 것도 하나의 방법입니다.

이와 관련하여 아래 유사한 질문들이 도움이 될 수 있습니다:

이 링크들은 SQL에서 인덱스 활용 및 최적화에 대해 더 깊은 이해를 도울 수 있습니다.

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

GROUP BY 시 인덱스를 타지 않는 이유가 궁금합니다

0

11

1

FOREIGN KEY 정리하기, 영상대로 SQL코드 복붙해도 안되요.

0

18

1

모델 서빙과 관련된 강좌 출시 예정된 바가 있으신지 여쭤봅니다!

0

19

2

트리거 질문

0

19

1

Vercel 실행이 안됩니다

0

14

1

패키지 구분에 대해 궁금한게 있습니다

0

17

2

노션 링크도 안 열리고, 알려준 vercel도 실행이 안됩니다.

0

20

1

Substack 1년 제공

1

26

3

특별 학습 자료 프로모션 1년 멤버십 무료 제공 문의드립니다

0

29

2

스프링부트 서버 에러나요

0

19

1

코드를 첨부해야하는 이유가 있나요?

0

22

2

간단한 오타 제보입니다.

0

21

1

큰 범위 조회 시 EXPLAIN의 rows 값이 정확하지 않은 이유가 궁금합니다.

0

39

2

실제 FK제약조건을 설정하지 않는이유

0

38

2

중고급 SQL과 실전 데이터 분석 101 문제 풀이, 13강 EXTRACT

0

84

1

28번 문제 답에대해서 질문드립니다.

0

98

1

중급 연습문제 25번

0

136

1

mysql 워크 벤치 커뮤니티 설치 중 에러

0

131

1

skill

0

208

3

sakila데이터베이스 다운했는데 값이 전부 null

0

176

1

연습문제 4번 관련

1

143

2

연습문제 37번 관련

0

169

2

연습문제 28번 관련

0

161

3

강의 내 연습문제 유형 관련

0

176

2