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 중국어 웹사이트의 기타 관련 기사를 참조하세요!