> 데이터 베이스 > MySQL 튜토리얼 > SQL에서 '단일 그룹 그룹 기능이 아님' 오류를 해결하는 방법은 무엇입니까?

SQL에서 '단일 그룹 그룹 기능이 아님' 오류를 해결하는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-12-29 09:31:15
원래의
600명이 탐색했습니다.

How to Solve the

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿