SQL 그룹화 함수 이해: "단일 그룹 그룹 함수가 아님" 오류 해결
SQL에서는 SUM( ) 여러 행의 값을 집계하여 특정 열을 기준으로 그룹화합니다. 그러나 SELECT 문에서 그룹 함수와 개별 열 표현식을 결합하려고 하면 "단일 그룹 그룹 함수가 아닙니다"라는 오류가 발생합니다. 이 오류는 그룹 함수가 개별 열 표현식과 동일한 그룹에 있는 데이터의 하위 집합에 대해 작동할 때 발생합니다.
이 문제를 해결하려면 다음 옵션을 고려하십시오.
1 . 그룹 함수 삭제:
SUM() 함수를 제거하면 집계된 값이 무효화되고 개별 열 표현식만 남습니다.
2. 개별 열 표현식 삭제:
SELECT 문에서 SSN 열을 제거하면 최대 합계 값을 반환하여 오류가 해결됩니다.
3. 포괄적인 GROUP BY 절 추가:
GROUP BY 절에 모든 개별 열 표현식을 포함하면 각 행이 그룹 함수의 범위와 일치하는 고유한 그룹에 속하게 됩니다. 그러나 여러 열로 그룹화하고 각 조합에 대해 고유한 값을 가지려는 경우 이 옵션은 적합하지 않을 수 있습니다.
검색을 위한 대체 쿼리:
주어진 경우 다운로드 수가 최대인 고객의 SSN을 찾는 목적으로 대체 쿼리를 사용하는 것이 좋습니다.
SELECT TOP 1 SSN, SUM(TIME) AS TotalTime FROM downloads GROUP BY SSN ORDER BY TotalTime DESC;
이 쿼리는 검색합니다. SSN과 각 SSN의 총 다운로드 시간을 총 시간을 기준으로 내림차순으로 정렬합니다. TOP 1 절은 총 시간이 가장 높은 SSN으로 결과를 제한합니다.
또는 여러 고객이 동일한 최대 총 시간을 공유하는 경우 다음 쿼리를 사용할 수 있습니다.
SELECT SSN, SUM(TIME) AS TotalTime FROM downloads GROUP BY SSN HAVING SUM(TIME) = (SELECT MAX(SUM(TIME)) FROM downloads GROUP BY SSN);
이 수정된 쿼리는 최대 총 다운로드 시간에 연결된 모든 SSN을 검색하여 정보가 손실되지 않도록 합니다.
위 내용은 SQL에서 '단일 그룹 그룹 기능이 아님' 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!