집 >데이터 베이스 >MySQL 튜토리얼 >여러 공급업체가 공급하는 부품을 찾기 위해 MySQL 하위 쿼리에서 GROUP 함수를 올바르게 사용하는 방법은 무엇입니까?
MySQL의 "잘못된 그룹 기능 사용" 오류 문제 해결
이 가이드에서는 여러 공급업체 및 부품과 관련된 데이터를 쿼리할 때 자주 발생하는 일반적인 MySQL 오류 "그룹 기능의 잘못된 사용"을 해결합니다. 목표는 최소 두 곳 이상의 공급업체에서 공급하는 부품을 찾는 것입니다.
핵심 문제는 하위 쿼리 내에서 WHERE
와 같은 집계 함수를 처리할 때 COUNT()
절을 오용하는 데 있습니다. WHERE
그룹화 전 개별 행을 필터링하고, 집계 HAVING
후 행 그룹을 필터링합니다. 부품당 공급업체 수(집계값)를 기준으로 필터링해야 하므로 은 필수입니다.HAVING
을 사용하여 기본 쿼리에서 해당 부품을 선택하는 것입니다. 중요한 변화는 하위 쿼리에서 IN
를 WHERE
으로 바꾸는 것입니다.HAVING
<code class="language-sql">( SELECT c2.pid FROM Catalog AS c2 GROUP BY c2.pid HAVING COUNT(DISTINCT c2.sid) >= 2 )</code>이 수정된 하위 쿼리는
을 사용하여 부품 ID별로 행을 그룹화하고 GROUP BY c2.pid
을 사용하여 이러한 그룹을 필터링하여 두 개 이상의 개별 공급업체 ID가 있는 그룹만 유지합니다. HAVING COUNT(DISTINCT c2.sid) >= 2
키워드는 동일한 부품을 여러 번 공급하더라도 각 공급업체가 한 번만 계산되도록 보장합니다.DISTINCT
을 사용하는 것을 기억하세요. 이러한 구분은 '그룹 기능 사용이 잘못되었습니다' 오류를 해결하고 원하는 데이터를 정확하게 검색하는 데 핵심입니다.HAVING
위 내용은 여러 공급업체가 공급하는 부품을 찾기 위해 MySQL 하위 쿼리에서 GROUP 함수를 올바르게 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!