강의

멘토링

커뮤니티

Cộng đồng Hỏi & Đáp của Inflearn

Hình ảnh hồ sơ của revi1337
revi1337

câu hỏi đã được viết

Nhập môn và Thực hành Tối ưu hóa hiệu suất MySQL dành cho cả người không chuyên (Phần Tuning SQL)

Tiếp theo nên học gì?

여러 테이블 조인시 where 절이 필요한가? 에 대해 질문있습니다.

Đã giải quyết

Viết

·

129

·

Đã chỉnh sửa

0

강사님 안녕하세요! 프로젝트를 끝내고 리팩토링을 하고이 있는데요.inner join 으로 3~4 개 정도의 테이블을 조인할 때, where 절이 과연 필요한가? 라는 궁금증이 생겼습니다.

 

기존에는 무지성 inner join 으로 테이블을 다 합친 후, where 절에서 필터링을 하고있었습니다. 근데 생각을 해보니 조인하려는 첫 테이블에 on 절로 추가 조건들을 넣어준다면.. 후에 조인하는 테이블들의 row 수를 줄일 수 있어 훨씬 효율적인것 같은데 (물론 인덱스도 타고).. 강사님은 어떻게 생각하시는지 궁금합니다.

 

단순히 하나의 테이블에 대한 row 만 가져올때는 where 절을 사용하고, 나머지 경우에는 where 절을 사용하지 않는게 훨 효율적이지 않나? 라는 생각이 들어서 이렇게 질문드립니다.

 

 

 

sqlmysqldbms/rdbmsquery-tuning

Câu trả lời 2

1

jscode님의 프로필 이미지
jscode
Người chia sẻ kiến thức

안녕하세요 PrivilegeEscalate님! 질문 잘 해주셨어요~~

기존에는 무지성 inner join 으로 테이블을 다 합친 후, where 절에서 필터링을 하고있었습니다. 근데 생각을 해보니 조인하려는 첫 테이블에 on 절로 추가 조건들을 넣어준다면.. 후에 조인하는 테이블들의 row 수를 줄일 수 있어 훨씬 효율적인것 같은데 (물론 인덱스도 타고)

-> 인덱스의 작동 과정과 어떻게 해야 데이터 조회 속도를 끌어올리는 지에 대해 확실하게 이해하신 것 같네요!! 말씀해주신 대로 조인을 다 하기 전에 on 조건으로 액세스 할 row 수를 줄일 수 있다면 훨씬 효율적일거예요!

하지만 무지성 inner join으로 테이블을 다 합친 후에 where 절에 필터링을 하더라도, 옵티마이저(SQL문을 최적화된 방법으로 실행시킬 수 있는 방법을 제공하는 장치)가 자체적으로 inner join을 수행하기 전에 where 문을 먼저 실행하기도 합니다!

따라서 가장 정확한 판단은 explain, explain analyze를 바탕으로 하나씩 테스트해보시면서 데이터 액세스를 줄일 수 있는 방법으로 쿼리를 수정하시면 좋을 것 같네요:D

 

이 외로 또 궁금하신 점 있으시면 질문 남겨주세요~~

PrivilegeEscalate님의 프로필 이미지
PrivilegeEscalate
Người đặt câu hỏi

하지만 무지성 inner join으로 테이블을 다 합친 후에 where 절에 필터링을 하더라도, 옵티마이저(SQL문을 최적화된 방법으로 실행시킬 수 있는 방법을 제공하는 장치)가 자체적으로 inner join을 수행하기 전에 where 문을 먼저 실행하기도 합니다!


와 이건 몰랐네요. 역시 실행계획이 정확하군요.. 정말정말 지긋지긋한 trade off 네요 ㅋㅋ!! 답변 정말 감사합니다!

0

안녕하세요, 인프런 AI 인턴입니다. PrivilegeEscalate님, 조인 쿼리에서 WHERE 절 사용 여부에 관한 흥미로운 질문을 주셨네요! 테이블 간 조인 시 성능 최적화는 매우 중요한 주제입니다.

조인 및 필터링 전략

  1. ON 절과 WHERE 절의 차이:

    • ON 절: 조인 조건을 명시하기 위해 사용됩니다. 테이블 간의 관계를 정의하고 조인을 수행하기 전, 데이터를 줄이는 데 도움을 줄 수 있습니다. 조인 시 조건을 미리 명시하면 조인되는 데이터의 수를 줄일 수 있습니다.
    • WHERE 절: 조인이 완료된 후 결과 테이블에 조건을 적용하여 필터링합니다. 이는 최종 데이터 셋을 줄이는 데 주로 사용됩니다.
  2. 성능 최적화 측면:

    • 조인을 수행하기 전에 데이터를 줄이는 것이 이상적입니다. 즉, 필요한 데이터를 먼저 제한하여 조인하는 것이 성능 최적화에 이롭습니다.
    • 조인하려는 테이블의 초기 테이블(기준 테이블)에서 필요한 조건을 ON 절에 최대한 포함시키는 것이 좋습니다. 이는 데이터베이스 엔진이 더 적은 데이터를 조인할 수 있게 하여 전체적인 효율성을 높입니다.
  3. 인덱스의 역할:

    • ON 절에 포함된 컬럼에 인덱스를 사용하는 것도 성능 향상에 중요한 요소입니다. 이는 조인 과정에서 조회할 데이터를 빠르게 찾을 수 있도록 도와줍니다.

추가 자료

  • 유사한 내용이 논의된 답변을 참고하시려면, 조인 및 필터링 전략에 관한 질문을 확인해 보세요. 여기서는 비슷한 상황에서의 조인 조건 설정 및 필터링에 관한 다양한 전략이 논의되고 있습니다.

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

Hình ảnh hồ sơ của revi1337
revi1337

câu hỏi đã được viết

Đặt câu hỏi