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