>데이터 베이스 >MySQL 튜토리얼 >MySQL 오류: '그룹 기능의 잘못된 사용'—WHERE 대 HAVING: 언제 어느 것을 사용해야 합니까?

MySQL 오류: '그룹 기능의 잘못된 사용'—WHERE 대 HAVING: 언제 어느 것을 사용해야 합니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-11 22:42:41780검색

MySQL Error:

MySQL 오류: 그룹화 기능을 잘못 사용했습니다.

MySQL을 사용할 때 "그룹화 함수의 잘못된 사용" 오류가 발생하는 경우 WHERE 절과 HAVING 절의 차이점을 이해해야 합니다.

제공된 쿼리의 목표는 두 개 이상의 공급업체에서 공급한 부품을 찾는 것입니다. 처음에는 WHERE 절을 사용하여 각 pid를 sids를 계산하는 하위 쿼리의 출력과 비교하려고 합니다. 그러나 MySQL은 집계 전에 WHERE를 수행하므로 이 접근 방식은 효과적이지 않습니다.

올바른 해결책은 HAVING 절을 사용하는 것입니다. HAVING은 COUNT()와 같은 집계 함수의 결과를 필터링하여 집계 후 계산을 수행할 수 있도록 합니다. 답변에 표시된 대로 HAVING을 사용하여 하위 쿼리를 다시 작성합니다.

<code class="language-sql">(
  SELECT c2.pid
  FROM Catalog AS c2
  WHERE c2.pid = c1.pid
  HAVING COUNT(c2.sid) >= 2
)</code>

원하는 결과를 얻을 수 있습니다. HAVING 절은 최소 두 개 이상의 공급업체가 있는 부품만 최종 출력에 포함되도록 보장합니다.

위 내용은 MySQL 오류: '그룹 기능의 잘못된 사용'—WHERE 대 HAVING: 언제 어느 것을 사용해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.