해결된 질문
작성
·
81
·
수정됨
0
강사님 안녕하세요! 프로젝트를 끝내고 리팩토링을 하고이 있는데요.inner join 으로 3~4 개 정도의 테이블을 조인할 때, where 절이 과연 필요한가? 라는 궁금증이 생겼습니다.
기존에는 무지성 inner join 으로 테이블을 다 합친 후, where 절에서 필터링을 하고있었습니다. 근데 생각을 해보니 조인하려는 첫 테이블에 on 절로 추가 조건들을 넣어준다면.. 후에 조인하는 테이블들의 row 수를 줄일 수 있어 훨씬 효율적인것 같은데 (물론 인덱스도 타고).. 강사님은 어떻게 생각하시는지 궁금합니다.
단순히 하나의 테이블에 대한 row 만 가져올때는 where 절을 사용하고, 나머지 경우에는 where 절을 사용하지 않는게 훨 효율적이지 않나? 라는 생각이 들어서 이렇게 질문드립니다.
답변 2
1
안녕하세요 PrivilegeEscalate님! 질문 잘 해주셨어요~~
기존에는 무지성 inner join 으로 테이블을 다 합친 후, where 절에서 필터링을 하고있었습니다. 근데 생각을 해보니 조인하려는 첫 테이블에 on 절로 추가 조건들을 넣어준다면.. 후에 조인하는 테이블들의 row 수를 줄일 수 있어 훨씬 효율적인것 같은데 (물론 인덱스도 타고)
-> 인덱스의 작동 과정과 어떻게 해야 데이터 조회 속도를 끌어올리는 지에 대해 확실하게 이해하신 것 같네요!! 말씀해주신 대로 조인을 다 하기 전에 on
조건으로 액세스 할 row 수를 줄일 수 있다면 훨씬 효율적일거예요!
하지만 무지성 inner join으로 테이블을 다 합친 후에 where 절에 필터링을 하더라도, 옵티마이저(SQL문을 최적화된 방법으로 실행시킬 수 있는 방법을 제공하는 장치)가 자체적으로 inner join을 수행하기 전에 where 문을 먼저 실행하기도 합니다!
따라서 가장 정확한 판단은 explain, explain analyze를 바탕으로 하나씩 테스트해보시면서 데이터 액세스를 줄일 수 있는 방법으로 쿼리를 수정하시면 좋을 것 같네요:D
이 외로 또 궁금하신 점 있으시면 질문 남겨주세요~~
0
안녕하세요, 인프런 AI 인턴입니다. PrivilegeEscalate님, 조인 쿼리에서 WHERE 절 사용 여부에 관한 흥미로운 질문을 주셨네요! 테이블 간 조인 시 성능 최적화는 매우 중요한 주제입니다.
ON 절과 WHERE 절의 차이:
성능 최적화 측면:
인덱스의 역할:
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
하지만 무지성 inner join으로 테이블을 다 합친 후에 where 절에 필터링을 하더라도, 옵티마이저(SQL문을 최적화된 방법으로 실행시킬 수 있는 방법을 제공하는 장치)가 자체적으로 inner join을 수행하기 전에 where 문을 먼저 실행하기도 합니다!
와 이건 몰랐네요. 역시 실행계획이 정확하군요.. 정말정말 지긋지긋한 trade off 네요 ㅋㅋ!! 답변 정말 감사합니다!