> 데이터 베이스 > MySQL 튜토리얼 > MySQL의 'GROUP 열 혼합' 오류(오류 #1140)를 해결하는 방법은 무엇입니까?

MySQL의 'GROUP 열 혼합' 오류(오류 #1140)를 해결하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-27 16:13:09
원래의
895명이 탐색했습니다.

How to Solve MySQL's

MySQL의 "Mixing of GROUP Columns" 오류 해결

MySQL의 #1140 오류는 "Mixing of GROUP columns"를 나타냅니다. 쿼리의 SELECT 절에 집계되지 않은(GROUP이 아닌) 열이 포함되어 있을 때 발생합니다. GROUP BY 절이 없는 집계된 열입니다. 이 문제를 해결하기 위한 두 가지 주요 접근 방식이 있습니다:

1. ONLY_FULL_GROUP_BY 비활성화:

MySQL에는 ONLY_FULL_GROUP_BY라는 구성 설정이 있으며 기본값은 ON입니다. 이 설정은 엄격한 GROUP BY 의미 체계를 적용하여 SELECT 절의 집계되지 않은 모든 열이 GROUP BY 목록에 포함되도록 요구합니다. 이 설정을 비활성화하려면 다음 쿼리를 실행하세요.

SET SESSION ONLY_FULL_GROUP_BY = OFF;
로그인 후 복사

ONLY_FULL_GROUP_BY를 비활성화하면 쿼리가 수정 없이 실행될 수 있습니다.

2. GROUP BY 열 추가:

또는 GROUP BY 절에 선택한 모든 필드를 포함하도록 쿼리를 수정할 수 있습니다. 이렇게 하면 집계되지 않은 모든 열이 "그룹화"되고 결과 집합이 엄격한 GROUP BY 의미 체계를 충족하게 됩니다.

SELECT COUNT(node.nid), 
       node.nid AS nid, 
       node_data_field_update_date.field_update_date_value AS node_data_field_update_date_field_update_date_value
FROM node node
LEFT JOIN content_type_update node_data_field_update_date ON node.vid = node_data_field_update_date.vid
WHERE node.type IN ('update')
GROUP BY node.nid, node_data_field_update_date.field_update_date_value
ORDER BY node_data_field_update_date_field_update_date_value DESC;
로그인 후 복사

GROUP BY 절을 포함하도록 쿼리를 수정하면 결과를 명시적으로 그룹화하여 문제가 해결됩니다. 집계되지 않은 모든 열에 설정됩니다.

위 내용은 MySQL의 'GROUP 열 혼합' 오류(오류 #1140)를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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