> 데이터 베이스 > MySQL 튜토리얼 > 내 SQL 쿼리에서 '단일 그룹 그룹 함수가 아님' 오류가 발생하는 이유는 무엇입니까?

내 SQL 쿼리에서 '단일 그룹 그룹 함수가 아님' 오류가 발생하는 이유는 무엇입니까?

DDD
풀어 주다: 2024-12-23 16:30:17
원래의
748명이 탐색했습니다.

Why Does My SQL Query Produce a

SQL의 "단일 그룹 그룹 함수가 아님" 오류 이해

SQL에서 다음과 같은 단일 그룹 그룹 함수 MAX(), SUM() 또는 AVG()는 지정된 그룹화 열에서 동일한 값을 갖는 행 그룹에 적용됩니다. 그러나 그룹 함수와 함께 SELECT 목록에 개별 열 표현식을 포함하고 GROUP BY 절에 해당 표현식을 모두 포함하지 않으려면 "단일 그룹 그룹 함수가 아님" 오류가 발생합니다.

문제 설명

예제 SQL 문에서 제공됨:

SELECT SSN, MAX(SUM(TIME))
FROM downloads
GROUP BY SSN
로그인 후 복사

쿼리는 각 고유 SSN에 대한 TIME 합계의 최대값을 계산한 다음 해당 최대값과 연관된 SSN을 반환하려고 시도합니다. 그러나 이 쿼리에는 근본적인 문제가 있습니다.

  • MAX(SUM(TIME)) 표현식은 각 SSN에 대한 TIME의 최대 합계를 계산하는 단일 그룹 그룹 함수입니다. 정의에 따르면 이는 각 SSN에 대해 하나의 결과만 있음을 의미합니다.
  • SELECT 목록에 개별 열 표현식 SSN을 포함하는 것은 SELECT 목록에 포함된 모든 개별 열 표현식도 SELECT 목록에 포함되어야 한다는 규칙을 위반하는 것입니다. GROUP BY 절.

해결

이 문제를 해결하려면 오류가 발생하면 세 가지 옵션이 있습니다.

  • SELECT 목록에서 개별 열 표현식(SSN)을 삭제합니다. 이렇게 하면 관련 SSN 없이 최대 TIME 합계가 제공됩니다.
  • GROUP BY 절에 개별 열 표현식(SSN)을 추가합니다. 이렇게 하면 두 가지 기준으로 결과가 그룹화됩니다. SSN 및 TIME을 사용하면 TIME의 최대 합계와 관련된 SSN을 검색할 수 있습니다.
  • 하위 쿼리 사용: 하위 쿼리를 사용하여 TIME의 최대 합계를 검색한 다음 이를 사용할 수 있습니다. 해당 SSN을 식별하기 위해 별도의 쿼리에 값을 추가합니다.

Option을 사용한 쿼리 예시 2

SELECT SSN, MAX(SUM(TIME))
FROM downloads
GROUP BY SSN, TIME
로그인 후 복사

이 쿼리는 SSN과 TIME을 기준으로 결과를 그룹화하므로 각 SSN에 대한 최대 TIME 합계와 관련된 SSN을 검색할 수 있습니다.

위 내용은 내 SQL 쿼리에서 '단일 그룹 그룹 함수가 아님' 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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