• 카테고리

    질문 & 답변
  • 세부 분야

    데이터베이스

  • 해결 여부

    해결됨

having 절과 where 절에서 상관서브쿼리 질문있습니다.

23.06.22 23:23 작성 조회수 168

0

강사님 , 항상 답변 감사합니다 (__)

having 절, group by 절에 상관 서브쿼리를 사용하지 않는게 좋다고 하셨습니다.

 

다시 생각을 해보니

WHERE 절에 상관 서브쿼리가 있다면

메인 쿼리에 로우 하나씩 상관 서브쿼리로 전달을 해서

상관 서브쿼리가 연산을 하는 것과

 

HAVING 절도 GROUP BY로 만들어진 결과를 로우 하나씩

상관 서브쿼리로 연산을 하는 것은

 

제가 생각하기에는 동일한 방식인거 같은데

having, group by 절에는 사용을 하지 말라고 하신지 궁금합니다.

답변 1

답변을 작성해보세요.

1

안녕하십니까,

강의에서도 말씀드리듯이, group by, having절에 서브쿼리를 사용은 할 수 있습니다만, 저는 가독성과 성능 측면에서 별로 적용할 이유가 없다고 봅니다.

먼저 group by 는 보통 특정 컬럼 기준값 또는 로직 기준값을 group을 하여 aggregate를 적용하기 위해서 사용하는데, 여기에 굳이 다른 테이블과 연결을 시키는 상관/비상관 서브쿼리를 사용할 필요는 없을 것 같습니다. 필요하다면 다른 테이블과 조인을 먼저 한 후에 필요한 컬럼으로 group by를 하면 될인데, 가독성(다른 사람이 해당 SQL을 보고 왜 이렇게 만들었는지 이유를 찾지 못한다던가) 측면이나 성능 측면(비 상관 서브쿼리시 다른 테이블에 연결을 해야 하는데, 성능 최적화 측면에서 무슨 문제가 나올지 저도 모르겠습니다)에서 좋을 이유가 없습니다.

저는 사용해 본적 없고, 사용한 경우도 보지 못했습니다.

having 절도 상관 서브쿼리는 마찬가지 개념입니다. 다만 having절의 비상관 서브쿼리는 이전에 질문하신 대로 적용이 필요하다면 적용하시면 될 것 같습니다.

다시 말씀드리지만, group by, having절에 서브쿼리를 사용할 수 있습니다. 필요하시다면 직접 적용해 보시고 판단해 보시기 바랍니다.

감사합니다.

cjh님의 프로필

cjh

질문자

2023.06.23

항상 감사합니다 강사님!! 다음 강의도 열심히 듣겠습니다